squidcloudctl 1.1.2 → 1.1.4

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 (258) hide show
  1. package/dist/auth-revoke-IRZJIB2A.js +2 -0
  2. package/dist/{auth-revoke-I5FM6N2S.js.map → auth-revoke-IRZJIB2A.js.map} +1 -1
  3. package/dist/auth-sessions-JZF7HUBL.js +2 -0
  4. package/dist/{auth-sessions-ALQEGBDS.js.map → auth-sessions-JZF7HUBL.js.map} +1 -1
  5. package/dist/auth-status-WHT7RXX6.js +2 -0
  6. package/dist/{auth-status-4VVTCDII.js.map → auth-status-WHT7RXX6.js.map} +1 -1
  7. package/dist/bin/squidcloud.js +1 -1
  8. package/dist/bin/squidcloud.js.map +1 -1
  9. package/dist/chunk-MU5KHPCI.js +2 -0
  10. package/dist/chunk-MU5KHPCI.js.map +1 -0
  11. package/dist/chunk-PSJQAIDB.js +2 -0
  12. package/dist/chunk-PSJQAIDB.js.map +1 -0
  13. package/dist/chunk-SVR7W7MP.js +3 -0
  14. package/dist/chunk-SVR7W7MP.js.map +1 -0
  15. package/dist/chunk-W6CRHANC.js +2 -0
  16. package/dist/chunk-W6CRHANC.js.map +1 -0
  17. package/dist/client-HD3YWJJJ.js +2 -0
  18. package/dist/{client-RFYERFWZ.js.map → client-HD3YWJJJ.js.map} +1 -1
  19. package/dist/{collab-activity-5RK36CJW.js → collab-activity-UNX2PJZE.js} +2 -2
  20. package/dist/{collab-activity-5RK36CJW.js.map → collab-activity-UNX2PJZE.js.map} +1 -1
  21. package/dist/collab-invite-Y54NCHSB.js +2 -0
  22. package/dist/{collab-invite-HAMMPEAQ.js.map → collab-invite-Y54NCHSB.js.map} +1 -1
  23. package/dist/collab-leave-CR4VOXZV.js +2 -0
  24. package/dist/{collab-leave-MTCXHQ4T.js.map → collab-leave-CR4VOXZV.js.map} +1 -1
  25. package/dist/collab-list-BHO5IEAR.js +2 -0
  26. package/dist/{collab-list-JV4ZCWLB.js.map → collab-list-BHO5IEAR.js.map} +1 -1
  27. package/dist/collab-remove-XI3NX2M7.js +2 -0
  28. package/dist/{collab-remove-DO4BIA5R.js.map → collab-remove-XI3NX2M7.js.map} +1 -1
  29. package/dist/collab-transfer-U4XXODAN.js +2 -0
  30. package/dist/{collab-transfer-6CG5PHVC.js.map → collab-transfer-U4XXODAN.js.map} +1 -1
  31. package/dist/deploy-5AQMGJ2Q.js +3 -0
  32. package/dist/{deploy-X5HX7V4J.js.map → deploy-5AQMGJ2Q.js.map} +1 -1
  33. package/dist/doctor-5TK2COIN.js +2 -0
  34. package/dist/{doctor-RSKBJYUX.js.map → doctor-5TK2COIN.js.map} +1 -1
  35. package/dist/forms-clear-4BQMLGGN.js +2 -0
  36. package/dist/{forms-clear-UJ23UHUN.js.map → forms-clear-4BQMLGGN.js.map} +1 -1
  37. package/dist/forms-create-ORURKN5O.js +2 -0
  38. package/dist/{forms-create-CWC7MGOJ.js.map → forms-create-ORURKN5O.js.map} +1 -1
  39. package/dist/forms-delete-NT4SAO6G.js +2 -0
  40. package/dist/{forms-delete-TKHTM6L5.js.map → forms-delete-NT4SAO6G.js.map} +1 -1
  41. package/dist/forms-embed-5L4DHGXC.js +3 -0
  42. package/dist/{forms-embed-FF3VMR4M.js.map → forms-embed-5L4DHGXC.js.map} +1 -1
  43. package/dist/forms-export-5SDRUFV3.js +2 -0
  44. package/dist/{forms-export-5ZNEL3V2.js.map → forms-export-5SDRUFV3.js.map} +1 -1
  45. package/dist/forms-info-JOYOMPC3.js +2 -0
  46. package/dist/{forms-info-SUST47TN.js.map → forms-info-JOYOMPC3.js.map} +1 -1
  47. package/dist/forms-list-CS7J3ULK.js +2 -0
  48. package/dist/{forms-list-W2UUPFFD.js.map → forms-list-CS7J3ULK.js.map} +1 -1
  49. package/dist/forms-submissions-KWGRYLAY.js +2 -0
  50. package/dist/{forms-submissions-UTLSYPWS.js.map → forms-submissions-KWGRYLAY.js.map} +1 -1
  51. package/dist/login-DRNKN2XZ.js +3 -0
  52. package/dist/login-DRNKN2XZ.js.map +1 -0
  53. package/dist/logout-UF55Z67V.js +2 -0
  54. package/dist/{logout-QERO6G6B.js.map → logout-UF55Z67V.js.map} +1 -1
  55. package/dist/logs-export-O74GEMCD.js +2 -0
  56. package/dist/{logs-export-DYOPV2LT.js.map → logs-export-O74GEMCD.js.map} +1 -1
  57. package/dist/logs-search-JAGCLPVE.js +2 -0
  58. package/dist/{logs-search-323KRPG4.js.map → logs-search-JAGCLPVE.js.map} +1 -1
  59. package/dist/{logs-tail-J64TCZG5.js → logs-tail-NFHOK3RM.js} +3 -3
  60. package/dist/{logs-tail-J64TCZG5.js.map → logs-tail-NFHOK3RM.js.map} +1 -1
  61. package/dist/monitor-ZLSLSVEZ.js +2 -0
  62. package/dist/{monitor-DKLGO5H7.js.map → monitor-ZLSLSVEZ.js.map} +1 -1
  63. package/dist/monitor-automations-VK6CZSNG.js +2 -0
  64. package/dist/{monitor-automations-4XOOCRFY.js.map → monitor-automations-VK6CZSNG.js.map} +1 -1
  65. package/dist/monitor-pipelines-WQOY5O4K.js +2 -0
  66. package/dist/{monitor-pipelines-EPL24J3S.js.map → monitor-pipelines-WQOY5O4K.js.map} +1 -1
  67. package/dist/monitor-sites-XRIEHVIV.js +2 -0
  68. package/dist/{monitor-sites-QIVG5TPF.js.map → monitor-sites-XRIEHVIV.js.map} +1 -1
  69. package/dist/monitor-storage-2ULH4E4F.js +2 -0
  70. package/dist/{monitor-storage-HBCC34K7.js.map → monitor-storage-2ULH4E4F.js.map} +1 -1
  71. package/dist/scripts-cancel-XYWJD3QW.js +2 -0
  72. package/dist/{scripts-cancel-JS3LL2AT.js.map → scripts-cancel-XYWJD3QW.js.map} +1 -1
  73. package/dist/scripts-delete-2EUZDGOW.js +2 -0
  74. package/dist/{scripts-delete-274TW63X.js.map → scripts-delete-2EUZDGOW.js.map} +1 -1
  75. package/dist/scripts-disable-7UQUGTO4.js +2 -0
  76. package/dist/{scripts-disable-JPATOVO4.js.map → scripts-disable-7UQUGTO4.js.map} +1 -1
  77. package/dist/scripts-enable-N7RK2ZRG.js +2 -0
  78. package/dist/{scripts-enable-JVAA6AMP.js.map → scripts-enable-N7RK2ZRG.js.map} +1 -1
  79. package/dist/scripts-list-F2RJ7TJ6.js +2 -0
  80. package/dist/{scripts-list-YPFNLI3P.js.map → scripts-list-F2RJ7TJ6.js.map} +1 -1
  81. package/dist/scripts-logs-PIIKLZXW.js +2 -0
  82. package/dist/{scripts-logs-VISO5ONQ.js.map → scripts-logs-PIIKLZXW.js.map} +1 -1
  83. package/dist/scripts-run-4EUWVBS6.js +2 -0
  84. package/dist/{scripts-run-3NBYKEMQ.js.map → scripts-run-4EUWVBS6.js.map} +1 -1
  85. package/dist/scripts-status-BVCSUDUA.js +2 -0
  86. package/dist/{scripts-status-45K3IL5L.js.map → scripts-status-BVCSUDUA.js.map} +1 -1
  87. package/dist/scripts-validate-TU47YDOT.js +2 -0
  88. package/dist/{scripts-validate-JZPIIMIX.js.map → scripts-validate-TU47YDOT.js.map} +1 -1
  89. package/dist/scripts-watch-TQURXMIL.js +2 -0
  90. package/dist/{scripts-watch-XZ7MZIMK.js.map → scripts-watch-TQURXMIL.js.map} +1 -1
  91. package/dist/session-R7SGJZAG.js +2 -0
  92. package/dist/{session-AZGWAAQQ.js.map → session-R7SGJZAG.js.map} +1 -1
  93. package/dist/sign-cancel-SOBRK2XX.js +2 -0
  94. package/dist/{sign-cancel-OUJM5UZT.js.map → sign-cancel-SOBRK2XX.js.map} +1 -1
  95. package/dist/sign-download-GLJS64WT.js +2 -0
  96. package/dist/{sign-download-FS5G6J27.js.map → sign-download-GLJS64WT.js.map} +1 -1
  97. package/dist/sign-list-ZMM7F4K2.js +2 -0
  98. package/dist/{sign-list-FV7SQSWT.js.map → sign-list-ZMM7F4K2.js.map} +1 -1
  99. package/dist/sign-request-PO24EDJG.js +2 -0
  100. package/dist/{sign-request-VVFYWT3Y.js.map → sign-request-PO24EDJG.js.map} +1 -1
  101. package/dist/sign-status-KD7I3PZH.js +2 -0
  102. package/dist/{sign-status-LKG5UFBX.js.map → sign-status-KD7I3PZH.js.map} +1 -1
  103. package/dist/sign-verify-LRZPLJYX.js +2 -0
  104. package/dist/{sign-verify-CVTTJSDL.js.map → sign-verify-LRZPLJYX.js.map} +1 -1
  105. package/dist/sites-analytics-RU63VLE4.js +2 -0
  106. package/dist/{sites-analytics-JK4UFMWX.js.map → sites-analytics-RU63VLE4.js.map} +1 -1
  107. package/dist/sites-delete-MGAIPA4A.js +2 -0
  108. package/dist/{sites-delete-SUHEQDZQ.js.map → sites-delete-MGAIPA4A.js.map} +1 -1
  109. package/dist/sites-deploys-UNRERGLN.js +2 -0
  110. package/dist/{sites-deploys-C4TVID2W.js.map → sites-deploys-UNRERGLN.js.map} +1 -1
  111. package/dist/sites-info-NVMVESXX.js +2 -0
  112. package/dist/{sites-info-BZUK57TH.js.map → sites-info-NVMVESXX.js.map} +1 -1
  113. package/dist/sites-list-KQZVB3Y2.js +2 -0
  114. package/dist/{sites-list-LLULSE5J.js.map → sites-list-KQZVB3Y2.js.map} +1 -1
  115. package/dist/sites-logs-MINP5YLW.js +3 -0
  116. package/dist/{sites-logs-NILNXF4L.js.map → sites-logs-MINP5YLW.js.map} +1 -1
  117. package/dist/sites-open-OZ5RORV4.js +3 -0
  118. package/dist/{sites-open-R7A5EQWM.js.map → sites-open-OZ5RORV4.js.map} +1 -1
  119. package/dist/sites-purge-K6CUCSQA.js +2 -0
  120. package/dist/{sites-purge-VHERQRUB.js.map → sites-purge-K6CUCSQA.js.map} +1 -1
  121. package/dist/sites-rename-HXM4MMDS.js +2 -0
  122. package/dist/{sites-rename-MOO6HVW3.js.map → sites-rename-HXM4MMDS.js.map} +1 -1
  123. package/dist/sites-rollback-FVELQVJK.js +2 -0
  124. package/dist/{sites-rollback-SPW2Z73L.js.map → sites-rollback-FVELQVJK.js.map} +1 -1
  125. package/dist/sites-unpublish-FQSQA763.js +2 -0
  126. package/dist/{sites-unpublish-6P7SQGIU.js.map → sites-unpublish-FQSQA763.js.map} +1 -1
  127. package/dist/sites-visibility-QDDJWBOT.js +2 -0
  128. package/dist/{sites-visibility-R3AQJ76F.js.map → sites-visibility-QDDJWBOT.js.map} +1 -1
  129. package/dist/storage-cat-TASP3DK7.js +2 -0
  130. package/dist/{storage-cat-HXFOJJG5.js.map → storage-cat-TASP3DK7.js.map} +1 -1
  131. package/dist/storage-clean-WCV7ENP2.js +2 -0
  132. package/dist/{storage-clean-LEQEYWL6.js.map → storage-clean-WCV7ENP2.js.map} +1 -1
  133. package/dist/storage-cp-PV6LPCYV.js +2 -0
  134. package/dist/{storage-cp-JTPTXZRQ.js.map → storage-cp-PV6LPCYV.js.map} +1 -1
  135. package/dist/storage-diff-BDKHYLIC.js +2 -0
  136. package/dist/{storage-diff-XURHVTPC.js.map → storage-diff-BDKHYLIC.js.map} +1 -1
  137. package/dist/storage-download-UEQYEO73.js +3 -0
  138. package/dist/{storage-download-5OYCNXKL.js.map → storage-download-UEQYEO73.js.map} +1 -1
  139. package/dist/storage-info-4IVQWOSM.js +2 -0
  140. package/dist/{storage-info-WA74POPR.js.map → storage-info-4IVQWOSM.js.map} +1 -1
  141. package/dist/storage-ls-AMBO3S2J.js +2 -0
  142. package/dist/{storage-ls-7RZQ3AXR.js.map → storage-ls-AMBO3S2J.js.map} +1 -1
  143. package/dist/storage-mkdir-5IXAS4YP.js +2 -0
  144. package/dist/{storage-mkdir-NWOHGAQI.js.map → storage-mkdir-5IXAS4YP.js.map} +1 -1
  145. package/dist/storage-mv-4DCYMNNI.js +2 -0
  146. package/dist/{storage-mv-XQ7EPX3M.js.map → storage-mv-4DCYMNNI.js.map} +1 -1
  147. package/dist/storage-rm-5K7F7ZP7.js +2 -0
  148. package/dist/{storage-rm-LYO6UR3G.js.map → storage-rm-5K7F7ZP7.js.map} +1 -1
  149. package/dist/storage-search-FCNFG2BS.js +2 -0
  150. package/dist/{storage-search-RIT5ISCA.js.map → storage-search-FCNFG2BS.js.map} +1 -1
  151. package/dist/storage-share-4PVM4QIC.js +2 -0
  152. package/dist/{storage-share-OURRQWZK.js.map → storage-share-4PVM4QIC.js.map} +1 -1
  153. package/dist/storage-tag-SXSOQVY6.js +2 -0
  154. package/dist/{storage-tag-NGJGUJSZ.js.map → storage-tag-SXSOQVY6.js.map} +1 -1
  155. package/dist/storage-unshare-EMXDT7DS.js +2 -0
  156. package/dist/{storage-unshare-3DXEKHEH.js.map → storage-unshare-EMXDT7DS.js.map} +1 -1
  157. package/dist/storage-upload-EHOTOYS5.js +2 -0
  158. package/dist/{storage-upload-5M6PBHOC.js.map → storage-upload-EHOTOYS5.js.map} +1 -1
  159. package/dist/time-list-2XMDLMRC.js +2 -0
  160. package/dist/{time-list-GMZYZAOU.js.map → time-list-2XMDLMRC.js.map} +1 -1
  161. package/dist/time-lock-WQKPTILH.js +2 -0
  162. package/dist/{time-lock-2OLEVQPJ.js.map → time-lock-WQKPTILH.js.map} +1 -1
  163. package/dist/time-proof-4YZLG6NG.js +2 -0
  164. package/dist/{time-proof-RUTDAEKP.js.map → time-proof-4YZLG6NG.js.map} +1 -1
  165. package/dist/time-status-YRQVIKNH.js +2 -0
  166. package/dist/{time-status-TVNJBFKC.js.map → time-status-YRQVIKNH.js.map} +1 -1
  167. package/dist/time-unlock-OUIAP7RY.js +2 -0
  168. package/dist/{time-unlock-OO6QH5R6.js.map → time-unlock-OUIAP7RY.js.map} +1 -1
  169. package/dist/{update-XJQSXSFU.js → update-DOHW47PB.js} +2 -2
  170. package/dist/{update-XJQSXSFU.js.map → update-DOHW47PB.js.map} +1 -1
  171. package/dist/whoami-ZFYNNZSF.js +2 -0
  172. package/dist/{whoami-SAURQARO.js.map → whoami-ZFYNNZSF.js.map} +1 -1
  173. package/package.json +1 -1
  174. package/dist/auth-revoke-I5FM6N2S.js +0 -2
  175. package/dist/auth-sessions-ALQEGBDS.js +0 -2
  176. package/dist/auth-status-4VVTCDII.js +0 -2
  177. package/dist/chunk-4NTVRCZM.js +0 -2
  178. package/dist/chunk-4NTVRCZM.js.map +0 -1
  179. package/dist/chunk-BC2OVPRV.js +0 -2
  180. package/dist/chunk-BC2OVPRV.js.map +0 -1
  181. package/dist/chunk-FYFPDKJM.js +0 -3
  182. package/dist/chunk-FYFPDKJM.js.map +0 -1
  183. package/dist/client-RFYERFWZ.js +0 -2
  184. package/dist/collab-invite-HAMMPEAQ.js +0 -2
  185. package/dist/collab-leave-MTCXHQ4T.js +0 -2
  186. package/dist/collab-list-JV4ZCWLB.js +0 -2
  187. package/dist/collab-remove-DO4BIA5R.js +0 -2
  188. package/dist/collab-transfer-6CG5PHVC.js +0 -2
  189. package/dist/deploy-X5HX7V4J.js +0 -3
  190. package/dist/doctor-RSKBJYUX.js +0 -2
  191. package/dist/forms-clear-UJ23UHUN.js +0 -2
  192. package/dist/forms-create-CWC7MGOJ.js +0 -2
  193. package/dist/forms-delete-TKHTM6L5.js +0 -2
  194. package/dist/forms-embed-FF3VMR4M.js +0 -3
  195. package/dist/forms-export-5ZNEL3V2.js +0 -2
  196. package/dist/forms-info-SUST47TN.js +0 -2
  197. package/dist/forms-list-W2UUPFFD.js +0 -2
  198. package/dist/forms-submissions-UTLSYPWS.js +0 -2
  199. package/dist/login-SO6BZ4HE.js +0 -2
  200. package/dist/login-SO6BZ4HE.js.map +0 -1
  201. package/dist/logout-QERO6G6B.js +0 -2
  202. package/dist/logs-export-DYOPV2LT.js +0 -2
  203. package/dist/logs-search-323KRPG4.js +0 -2
  204. package/dist/monitor-DKLGO5H7.js +0 -2
  205. package/dist/monitor-automations-4XOOCRFY.js +0 -2
  206. package/dist/monitor-pipelines-EPL24J3S.js +0 -2
  207. package/dist/monitor-sites-QIVG5TPF.js +0 -2
  208. package/dist/monitor-storage-HBCC34K7.js +0 -2
  209. package/dist/scripts-cancel-JS3LL2AT.js +0 -2
  210. package/dist/scripts-delete-274TW63X.js +0 -2
  211. package/dist/scripts-disable-JPATOVO4.js +0 -2
  212. package/dist/scripts-enable-JVAA6AMP.js +0 -2
  213. package/dist/scripts-list-YPFNLI3P.js +0 -2
  214. package/dist/scripts-logs-VISO5ONQ.js +0 -2
  215. package/dist/scripts-run-3NBYKEMQ.js +0 -2
  216. package/dist/scripts-status-45K3IL5L.js +0 -2
  217. package/dist/scripts-validate-JZPIIMIX.js +0 -2
  218. package/dist/scripts-watch-XZ7MZIMK.js +0 -2
  219. package/dist/session-AZGWAAQQ.js +0 -2
  220. package/dist/sign-cancel-OUJM5UZT.js +0 -2
  221. package/dist/sign-download-FS5G6J27.js +0 -2
  222. package/dist/sign-list-FV7SQSWT.js +0 -2
  223. package/dist/sign-request-VVFYWT3Y.js +0 -2
  224. package/dist/sign-status-LKG5UFBX.js +0 -2
  225. package/dist/sign-verify-CVTTJSDL.js +0 -2
  226. package/dist/sites-analytics-JK4UFMWX.js +0 -2
  227. package/dist/sites-delete-SUHEQDZQ.js +0 -2
  228. package/dist/sites-deploys-C4TVID2W.js +0 -2
  229. package/dist/sites-info-BZUK57TH.js +0 -2
  230. package/dist/sites-list-LLULSE5J.js +0 -2
  231. package/dist/sites-logs-NILNXF4L.js +0 -3
  232. package/dist/sites-open-R7A5EQWM.js +0 -3
  233. package/dist/sites-purge-VHERQRUB.js +0 -2
  234. package/dist/sites-rename-MOO6HVW3.js +0 -2
  235. package/dist/sites-rollback-SPW2Z73L.js +0 -2
  236. package/dist/sites-unpublish-6P7SQGIU.js +0 -2
  237. package/dist/sites-visibility-R3AQJ76F.js +0 -2
  238. package/dist/storage-cat-HXFOJJG5.js +0 -2
  239. package/dist/storage-clean-LEQEYWL6.js +0 -2
  240. package/dist/storage-cp-JTPTXZRQ.js +0 -2
  241. package/dist/storage-diff-XURHVTPC.js +0 -2
  242. package/dist/storage-download-5OYCNXKL.js +0 -3
  243. package/dist/storage-info-WA74POPR.js +0 -2
  244. package/dist/storage-ls-7RZQ3AXR.js +0 -2
  245. package/dist/storage-mkdir-NWOHGAQI.js +0 -2
  246. package/dist/storage-mv-XQ7EPX3M.js +0 -2
  247. package/dist/storage-rm-LYO6UR3G.js +0 -2
  248. package/dist/storage-search-RIT5ISCA.js +0 -2
  249. package/dist/storage-share-OURRQWZK.js +0 -2
  250. package/dist/storage-tag-NGJGUJSZ.js +0 -2
  251. package/dist/storage-unshare-3DXEKHEH.js +0 -2
  252. package/dist/storage-upload-5M6PBHOC.js +0 -2
  253. package/dist/time-list-GMZYZAOU.js +0 -2
  254. package/dist/time-lock-2OLEVQPJ.js +0 -2
  255. package/dist/time-proof-RUTDAEKP.js +0 -2
  256. package/dist/time-status-TVNJBFKC.js +0 -2
  257. package/dist/time-unlock-OO6QH5R6.js +0 -2
  258. package/dist/whoami-SAURQARO.js +0 -2
@@ -0,0 +1,2 @@
1
+ import e from'os';import y from'path';import n,{existsSync,readFileSync}from'fs';import {concatBytes,randomBytes}from'@noble/hashes/utils';import {sha256}from'@noble/hashes/sha256';import {hkdf}from'@noble/hashes/hkdf';import {gcm}from'@noble/ciphers/aes';import {etc}from'@noble/ed25519';import'@noble/curves/ed25519.js';import {sha512}from'@noble/hashes/sha512';import {hmac}from'@noble/hashes/hmac';import {blake3}from'@noble/hashes/blake3';import {createHash}from'crypto';etc.sha512Sync=(...t)=>sha512(concatBytes(...t));function ot(t,r){return Buffer.from(hmac(sha256,t,r)).toString("hex")}function o(t){return Buffer.from(t).toString("hex")}function p(t){return new Uint8Array(Buffer.from(t,"hex"))}var P=["/etc/machine-id","/var/lib/dbus/machine-id","/etc/hostid"];function D(){for(let r of P)try{if(existsSync(r))return readFileSync(r,"utf-8").trim()}catch{continue}return createHash("sha256").update(e.hostname()+e.arch()+e.platform()).digest("hex")}function f(){let i=[D(),e.hostname(),e.platform(),e.arch(),e.release()].join(":");return o(blake3(i))}var m=y.join(e.homedir(),".squidcloud"),s=y.join(m,".session");function g(){let t=f(),r=new TextEncoder().encode(t);return hkdf(sha256,r,new Uint8Array(32),"squidcloud-fallback-v1",32)}async function l(t){let r=g(),i=randomBytes(12),c=new TextEncoder().encode(t),u=gcm(r,i).encrypt(c);n.existsSync(m)||n.mkdirSync(m,{recursive:true,mode:448});let x={iv:o(i),data:o(u)};n.writeFileSync(s,JSON.stringify(x),{mode:384,encoding:"utf-8"});}async function S(){try{if(!n.existsSync(s))return null;let t=n.readFileSync(s,"utf-8"),{iv:r,data:i}=JSON.parse(t),c=g(),u=gcm(c,p(r)).decrypt(p(i));return new TextDecoder().decode(u)}catch{return null}}async function a(){try{n.existsSync(s)&&n.unlinkSync(s);}catch{}}async function bt(){try{let t=await S();if(!t)return null;let r=JSON.parse(t);return !r.session_id||!r.access_token?(await a(),null):r}catch{return await a(),null}}async function kt(t){await l(JSON.stringify(t));}async function Bt(){await a();}function qt(t){return Date.now()>=t.expires_at}function Pt(t){return t.expires_at-Date.now()<=12e4}function Dt(t){return t.expires_at-Date.now()}export{ot as a,o as b,f as c,bt as d,kt as e,Bt as f,qt as g,Pt as h,Dt as i};//# sourceMappingURL=chunk-W6CRHANC.js.map
2
+ //# sourceMappingURL=chunk-W6CRHANC.js.map
@@ -0,0 +1 @@
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":["etc","msgs","sha512","concatBytes","computeHMAC","key","data","hmac","sha256","bytesToHex","buf","hexToBytes","hex","MACHINE_ID_PATHS","getMachineId","p","existsSync","readFileSync","createHash","os","computeDeviceFingerprint","blake3","FALLBACK_DIR","path","FALLBACK_FILE","getFallbackKey","fingerprint","ikm","hkdf","storeSession","sessionJson","iv","randomBytes","plaintext","encrypted","gcm","fs","payload","getSession","raw","decrypted","deleteSession","loadSession","session","saveSession","clearSession","isSessionExpired","shouldRefreshToken","getTimeUntilExpiry"],"mappings":"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","file":"chunk-W6CRHANC.js","sourcesContent":["import { getPublicKey, sign, verify, etc, utils as edUtils } from '@noble/ed25519'\nimport { x25519 } from '@noble/curves/ed25519.js'\nimport { sha256 } from '@noble/hashes/sha256'\nimport { sha512 } from '@noble/hashes/sha512'\nimport { hmac } from '@noble/hashes/hmac'\nimport { hkdf } from '@noble/hashes/hkdf'\nimport { blake3 } from '@noble/hashes/blake3'\nimport { randomBytes, concatBytes } from '@noble/hashes/utils'\nimport { gcm } from '@noble/ciphers/aes'\nimport { pbkdf2Sync } from 'node:crypto'\nimport { hostname, platform, arch } from 'node:os'\n\netc.sha512Sync = (...msgs: Uint8Array[]) => sha512(concatBytes(...msgs))\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"]}
@@ -0,0 +1,2 @@
1
+ export{b as ApiError,f as apiDelete,c as apiGet,d as apiPost,e as apiPut,a as apiRequest,g as apiUpload}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-W6CRHANC.js';//# sourceMappingURL=client-HD3YWJJJ.js.map
2
+ //# sourceMappingURL=client-HD3YWJJJ.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"client-RFYERFWZ.js"}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"client-HD3YWJJJ.js"}
@@ -1,2 +1,2 @@
1
- import {a}from'./chunk-NDB6KXYI.js';import {m}from'./chunk-4NTVRCZM.js';import {WebSocket}from'ws';import e from'chalk';async function f(r){let i=await m();i||(console.error("Not authenticated"),process.exit(1));let a$1=a().replace(/^http/,"ws"),s=new WebSocket(`${a$1}/api/v1/collab/${encodeURIComponent(r)}/activity`,{headers:{Authorization:`Bearer ${i.access_token}`}});console.log(e.dim(`Streaming activity for "${r}"... (Ctrl+C to stop)`)),s.on("message",t=>{try{let o=JSON.parse(t.toString()),l=e.dim(new Date(o.timestamp).toLocaleTimeString()),p=e.hex("#4FC3F7")(o.user||"unknown"),m=o.action==="upload"?e.green("uploaded"):o.action==="delete"?e.red("deleted"):o.action==="edit"?e.yellow("edited"):o.action,d=o.file||o.path||"";console.log(`${l} ${p} ${m} ${d}`);}catch{console.log(t.toString());}}),s.on("error",t=>{console.error(e.red(`Error: ${t.message}`)),process.exit(1);}),process.on("SIGINT",()=>{s.close(),process.exit(0);});}export{f as default};//# sourceMappingURL=collab-activity-5RK36CJW.js.map
2
- //# sourceMappingURL=collab-activity-5RK36CJW.js.map
1
+ import {a}from'./chunk-NDB6KXYI.js';import {d}from'./chunk-W6CRHANC.js';import {WebSocket}from'ws';import e from'chalk';async function f(r){let i=await d();i||(console.error("Not authenticated"),process.exit(1));let a$1=a().replace(/^http/,"ws"),s=new WebSocket(`${a$1}/api/v1/collab/${encodeURIComponent(r)}/activity`,{headers:{Authorization:`Bearer ${i.access_token}`}});console.log(e.dim(`Streaming activity for "${r}"... (Ctrl+C to stop)`)),s.on("message",t=>{try{let o=JSON.parse(t.toString()),l=e.dim(new Date(o.timestamp).toLocaleTimeString()),p=e.hex("#4FC3F7")(o.user||"unknown"),m=o.action==="upload"?e.green("uploaded"):o.action==="delete"?e.red("deleted"):o.action==="edit"?e.yellow("edited"):o.action,d=o.file||o.path||"";console.log(`${l} ${p} ${m} ${d}`);}catch{console.log(t.toString());}}),s.on("error",t=>{console.error(e.red(`Error: ${t.message}`)),process.exit(1);}),process.on("SIGINT",()=>{s.close(),process.exit(0);});}export{f as default};//# sourceMappingURL=collab-activity-UNX2PJZE.js.map
2
+ //# sourceMappingURL=collab-activity-UNX2PJZE.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/collab/collab-activity.ts"],"names":["collabActivity","folder","session","loadSession","apiBase","getApiBase","ws","WebSocket","chalk","data","e","ts","user","action","file","err"],"mappings":"wHAKA,eAAOA,CAAAA,CAAsCC,CAAAA,CAA+B,CAC1E,IAAMC,CAAAA,CAAU,MAAMC,CAAAA,EAAY,CAC7BD,IAAW,OAAA,CAAQ,KAAA,CAAM,mBAAmB,CAAA,CAAG,OAAA,CAAQ,KAAK,CAAC,CAAA,CAAA,CAElE,IAAME,GAAAA,CAAUC,CAAAA,GAAa,OAAA,CAAQ,OAAA,CAAS,IAAI,CAAA,CAC5CC,CAAAA,CAAK,IAAIC,SAAAA,CAAU,CAAA,EAAGH,GAAO,CAAA,eAAA,EAAkB,kBAAA,CAAmBH,CAAM,CAAC,CAAA,SAAA,CAAA,CAAa,CAC1F,OAAA,CAAS,CAAE,aAAA,CAAe,CAAA,OAAA,EAAUC,EAAQ,YAAY,CAAA,CAAG,CAC7D,CAAC,CAAA,CAED,QAAQ,GAAA,CAAIM,CAAAA,CAAM,IAAI,CAAA,wBAAA,EAA2BP,CAAM,uBAAuB,CAAC,CAAA,CAC/EK,EAAG,EAAA,CAAG,SAAA,CAAYG,GAAiB,CACjC,GAAI,CACF,IAAMC,CAAAA,CAAI,KAAK,KAAA,CAAMD,CAAAA,CAAK,UAAU,CAAA,CAC9BE,EAAKH,CAAAA,CAAM,GAAA,CAAI,IAAI,IAAA,CAAKE,CAAAA,CAAE,SAAS,CAAA,CAAE,kBAAA,EAAoB,CAAA,CACzDE,CAAAA,CAAOJ,EAAM,GAAA,CAAI,SAAS,CAAA,CAAEE,CAAAA,CAAE,MAAQ,SAAS,CAAA,CAC/CG,EAASH,CAAAA,CAAE,MAAA,GAAW,SAAWF,CAAAA,CAAM,KAAA,CAAM,UAAU,CAAA,CAC3DE,CAAAA,CAAE,SAAW,QAAA,CAAWF,CAAAA,CAAM,IAAI,SAAS,CAAA,CAC3CE,EAAE,MAAA,GAAW,MAAA,CAASF,EAAM,MAAA,CAAO,QAAQ,EAAIE,CAAAA,CAAE,MAAA,CAC7CI,EAAOJ,CAAAA,CAAE,IAAA,EAAQA,EAAE,IAAA,EAAQ,EAAA,CACjC,QAAQ,GAAA,CAAI,CAAA,EAAGC,CAAE,CAAA,CAAA,EAAIC,CAAI,IAAIC,CAAM,CAAA,CAAA,EAAIC,CAAI,CAAA,CAAE,EAC/C,CAAA,KAAQ,CACN,QAAQ,GAAA,CAAIL,CAAAA,CAAK,UAAU,EAC7B,CACF,CAAC,CAAA,CACDH,EAAG,EAAA,CAAG,OAAA,CAAUS,GAAQ,CAAE,OAAA,CAAQ,MAAMP,CAAAA,CAAM,GAAA,CAAI,UAAUO,CAAAA,CAAI,OAAO,EAAE,CAAC,CAAA,CAAG,QAAQ,IAAA,CAAK,CAAC,EAAE,CAAC,CAAA,CAC9F,QAAQ,EAAA,CAAG,QAAA,CAAU,IAAM,CAAET,CAAAA,CAAG,OAAM,CAAG,OAAA,CAAQ,KAAK,CAAC,EAAE,CAAC,EAC5D","file":"collab-activity-5RK36CJW.js","sourcesContent":["import { WebSocket } from 'ws'\nimport chalk from 'chalk'\nimport { loadSession } from '../../lib/auth/session.js'\nimport { getApiBase } from '../../lib/api/cert-pin.js'\n\nexport default async function collabActivity(folder: string): Promise<void> {\n const session = await loadSession()\n if (!session) { console.error('Not authenticated'); process.exit(1) }\n\n const apiBase = getApiBase().replace(/^http/, 'ws')\n const ws = new WebSocket(`${apiBase}/api/v1/collab/${encodeURIComponent(folder)}/activity`, {\n headers: { Authorization: `Bearer ${session.access_token}` },\n })\n\n console.log(chalk.dim(`Streaming activity for \"${folder}\"... (Ctrl+C to stop)`))\n ws.on('message', (data: Buffer) => {\n try {\n const e = JSON.parse(data.toString())\n const ts = chalk.dim(new Date(e.timestamp).toLocaleTimeString())\n const user = chalk.hex('#4FC3F7')(e.user || 'unknown')\n const action = e.action === 'upload' ? chalk.green('uploaded') :\n e.action === 'delete' ? chalk.red('deleted') :\n e.action === 'edit' ? chalk.yellow('edited') : e.action\n const file = e.file || e.path || ''\n console.log(`${ts} ${user} ${action} ${file}`)\n } catch {\n console.log(data.toString())\n }\n })\n ws.on('error', (err) => { console.error(chalk.red(`Error: ${err.message}`)); process.exit(1) })\n process.on('SIGINT', () => { ws.close(); process.exit(0) })\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/collab/collab-activity.ts"],"names":["collabActivity","folder","session","loadSession","apiBase","getApiBase","ws","WebSocket","chalk","data","e","ts","user","action","file","err"],"mappings":"wHAKA,eAAOA,CAAAA,CAAsCC,CAAAA,CAA+B,CAC1E,IAAMC,CAAAA,CAAU,MAAMC,CAAAA,EAAY,CAC7BD,IAAW,OAAA,CAAQ,KAAA,CAAM,mBAAmB,CAAA,CAAG,OAAA,CAAQ,KAAK,CAAC,CAAA,CAAA,CAElE,IAAME,GAAAA,CAAUC,CAAAA,GAAa,OAAA,CAAQ,OAAA,CAAS,IAAI,CAAA,CAC5CC,CAAAA,CAAK,IAAIC,SAAAA,CAAU,CAAA,EAAGH,GAAO,CAAA,eAAA,EAAkB,kBAAA,CAAmBH,CAAM,CAAC,CAAA,SAAA,CAAA,CAAa,CAC1F,OAAA,CAAS,CAAE,aAAA,CAAe,CAAA,OAAA,EAAUC,EAAQ,YAAY,CAAA,CAAG,CAC7D,CAAC,CAAA,CAED,QAAQ,GAAA,CAAIM,CAAAA,CAAM,IAAI,CAAA,wBAAA,EAA2BP,CAAM,uBAAuB,CAAC,CAAA,CAC/EK,EAAG,EAAA,CAAG,SAAA,CAAYG,GAAiB,CACjC,GAAI,CACF,IAAMC,CAAAA,CAAI,KAAK,KAAA,CAAMD,CAAAA,CAAK,UAAU,CAAA,CAC9BE,EAAKH,CAAAA,CAAM,GAAA,CAAI,IAAI,IAAA,CAAKE,CAAAA,CAAE,SAAS,CAAA,CAAE,kBAAA,EAAoB,CAAA,CACzDE,CAAAA,CAAOJ,EAAM,GAAA,CAAI,SAAS,CAAA,CAAEE,CAAAA,CAAE,MAAQ,SAAS,CAAA,CAC/CG,EAASH,CAAAA,CAAE,MAAA,GAAW,SAAWF,CAAAA,CAAM,KAAA,CAAM,UAAU,CAAA,CAC3DE,CAAAA,CAAE,SAAW,QAAA,CAAWF,CAAAA,CAAM,IAAI,SAAS,CAAA,CAC3CE,EAAE,MAAA,GAAW,MAAA,CAASF,EAAM,MAAA,CAAO,QAAQ,EAAIE,CAAAA,CAAE,MAAA,CAC7CI,EAAOJ,CAAAA,CAAE,IAAA,EAAQA,EAAE,IAAA,EAAQ,EAAA,CACjC,QAAQ,GAAA,CAAI,CAAA,EAAGC,CAAE,CAAA,CAAA,EAAIC,CAAI,IAAIC,CAAM,CAAA,CAAA,EAAIC,CAAI,CAAA,CAAE,EAC/C,CAAA,KAAQ,CACN,QAAQ,GAAA,CAAIL,CAAAA,CAAK,UAAU,EAC7B,CACF,CAAC,CAAA,CACDH,EAAG,EAAA,CAAG,OAAA,CAAUS,GAAQ,CAAE,OAAA,CAAQ,MAAMP,CAAAA,CAAM,GAAA,CAAI,UAAUO,CAAAA,CAAI,OAAO,EAAE,CAAC,CAAA,CAAG,QAAQ,IAAA,CAAK,CAAC,EAAE,CAAC,CAAA,CAC9F,QAAQ,EAAA,CAAG,QAAA,CAAU,IAAM,CAAET,CAAAA,CAAG,OAAM,CAAG,OAAA,CAAQ,KAAK,CAAC,EAAE,CAAC,EAC5D","file":"collab-activity-UNX2PJZE.js","sourcesContent":["import { WebSocket } from 'ws'\nimport chalk from 'chalk'\nimport { loadSession } from '../../lib/auth/session.js'\nimport { getApiBase } from '../../lib/api/cert-pin.js'\n\nexport default async function collabActivity(folder: string): Promise<void> {\n const session = await loadSession()\n if (!session) { console.error('Not authenticated'); process.exit(1) }\n\n const apiBase = getApiBase().replace(/^http/, 'ws')\n const ws = new WebSocket(`${apiBase}/api/v1/collab/${encodeURIComponent(folder)}/activity`, {\n headers: { Authorization: `Bearer ${session.access_token}` },\n })\n\n console.log(chalk.dim(`Streaming activity for \"${folder}\"... (Ctrl+C to stop)`))\n ws.on('message', (data: Buffer) => {\n try {\n const e = JSON.parse(data.toString())\n const ts = chalk.dim(new Date(e.timestamp).toLocaleTimeString())\n const user = chalk.hex('#4FC3F7')(e.user || 'unknown')\n const action = e.action === 'upload' ? chalk.green('uploaded') :\n e.action === 'delete' ? chalk.red('deleted') :\n e.action === 'edit' ? chalk.yellow('edited') : e.action\n const file = e.file || e.path || ''\n console.log(`${ts} ${user} ${action} ${file}`)\n } catch {\n console.log(data.toString())\n }\n })\n ws.on('error', (err) => { console.error(chalk.red(`Error: ${err.message}`)); process.exit(1) })\n process.on('SIGINT', () => { ws.close(); process.exit(0) })\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';async function m(i,e){let t=a(`Inviting ${e.email} to "${i}" as ${e.role}...`);t.start(),await d("/api/v1/collab/invite",{folder:i,email:e.email,role:e.role},{authenticated:true}),t.succeed(),g(`Invited ${e.email} to "${i}" as ${e.role}`);}export{m as default};//# sourceMappingURL=collab-invite-Y54NCHSB.js.map
2
+ //# sourceMappingURL=collab-invite-Y54NCHSB.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/collab/collab-invite.ts"],"names":["collabInvite","folder","options","spinner","createSpinner","apiPost","logSuccess"],"mappings":"gMAIA,eAAOA,CAAAA,CAAoCC,EAAgBC,GAAAA,CAAyD,CAClH,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,CAAA,SAAA,EAAYF,GAAAA,CAAQ,KAAK,CAAA,KAAA,EAAQD,CAAM,CAAA,KAAA,EAAQC,GAAAA,CAAQ,IAAI,CAAA,GAAA,CAAK,CAAA,CAC9FC,CAAAA,CAAQ,OAAM,CACd,MAAME,CAAAA,CAAQ,uBAAA,CAAyB,CACrC,MAAA,CAAAJ,EACA,KAAA,CAAOC,GAAAA,CAAQ,KAAA,CACf,IAAA,CAAMA,GAAAA,CAAQ,IAChB,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC1BC,CAAAA,CAAQ,SAAQ,CAChBG,CAAAA,CAAW,CAAA,QAAA,EAAWJ,GAAAA,CAAQ,KAAK,CAAA,KAAA,EAAQD,CAAM,CAAA,KAAA,EAAQC,GAAAA,CAAQ,IAAI,CAAA,CAAE,EACzE","file":"collab-invite-HAMMPEAQ.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 collabInvite(folder: string, options: { email: string; role: string }): Promise<void> {\n const spinner = createSpinner(`Inviting ${options.email} to \"${folder}\" as ${options.role}...`)\n spinner.start()\n await apiPost('/api/v1/collab/invite', {\n folder,\n email: options.email,\n role: options.role,\n }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Invited ${options.email} to \"${folder}\" as ${options.role}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/collab/collab-invite.ts"],"names":["collabInvite","folder","options","spinner","createSpinner","apiPost","logSuccess"],"mappings":"4NAIA,eAAOA,CAAAA,CAAoCC,EAAgBC,CAAAA,CAAyD,CAClH,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,CAAA,SAAA,EAAYF,CAAAA,CAAQ,KAAK,CAAA,KAAA,EAAQD,CAAM,CAAA,KAAA,EAAQC,CAAAA,CAAQ,IAAI,CAAA,GAAA,CAAK,CAAA,CAC9FC,CAAAA,CAAQ,OAAM,CACd,MAAME,CAAAA,CAAQ,uBAAA,CAAyB,CACrC,MAAA,CAAAJ,EACA,KAAA,CAAOC,CAAAA,CAAQ,KAAA,CACf,IAAA,CAAMA,CAAAA,CAAQ,IAChB,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC1BC,CAAAA,CAAQ,SAAQ,CAChBG,CAAAA,CAAW,CAAA,QAAA,EAAWJ,CAAAA,CAAQ,KAAK,CAAA,KAAA,EAAQD,CAAM,CAAA,KAAA,EAAQC,CAAAA,CAAQ,IAAI,CAAA,CAAE,EACzE","file":"collab-invite-Y54NCHSB.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 collabInvite(folder: string, options: { email: string; role: string }): Promise<void> {\n const spinner = createSpinner(`Inviting ${options.email} to \"${folder}\" as ${options.role}...`)\n spinner.start()\n await apiPost('/api/v1/collab/invite', {\n folder,\n email: options.email,\n role: options.role,\n }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Invited ${options.email} to \"${folder}\" as ${options.role}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import n from'inquirer';async function m(e){let{confirm:a$1}=await n.prompt([{type:"confirm",name:"confirm",message:`Remove yourself from "${e}"?`,default:false}]);if(!a$1)return;let t=a(`Leaving "${e}"...`);t.start(),await d("/api/v1/collab/leave",{folder:e},{authenticated:true}),t.succeed(),g(`You left "${e}"`);}export{m as default};//# sourceMappingURL=collab-leave-CR4VOXZV.js.map
2
+ //# sourceMappingURL=collab-leave-CR4VOXZV.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/collab/collab-leave.ts"],"names":["collabLeave","folder","confirm","inquirer","spinner","createSpinner","apiPost","logSuccess"],"mappings":"wNAKA,eAAOA,CAAAA,CAAmCC,GAAAA,CAA+B,CACvE,GAAM,CAAE,OAAA,CAAAC,CAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,SAAA,CACN,IAAA,CAAM,SAAA,CACN,OAAA,CAAS,CAAA,sBAAA,EAAyBF,GAAM,CAAA,EAAA,CAAA,CACxC,OAAA,CAAS,KACX,CAAC,CAAC,EACF,GAAI,CAACC,CAAAA,CAAS,OACd,IAAME,CAAAA,CAAUC,CAAAA,CAAc,CAAA,SAAA,EAAYJ,GAAM,CAAA,IAAA,CAAM,CAAA,CACtDG,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,sBAAA,CAAwB,CAAE,MAAA,CAAAL,GAAO,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACzEG,CAAAA,CAAQ,OAAA,EAAQ,CAChBG,CAAAA,CAAW,CAAA,UAAA,EAAaN,GAAM,GAAG,EACnC","file":"collab-leave-MTCXHQ4T.js","sourcesContent":["import inquirer from 'inquirer'\nimport { 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 collabLeave(folder: string): Promise<void> {\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: `Remove yourself from \"${folder}\"?`,\n default: false,\n }])\n if (!confirm) return\n const spinner = createSpinner(`Leaving \"${folder}\"...`)\n spinner.start()\n await apiPost('/api/v1/collab/leave', { folder }, { authenticated: true })\n spinner.succeed()\n logSuccess(`You left \"${folder}\"`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/collab/collab-leave.ts"],"names":["collabLeave","folder","confirm","inquirer","spinner","createSpinner","apiPost","logSuccess"],"mappings":"oPAKA,eAAOA,CAAAA,CAAmCC,CAAAA,CAA+B,CACvE,GAAM,CAAE,OAAA,CAAAC,GAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,SAAA,CACN,IAAA,CAAM,SAAA,CACN,OAAA,CAAS,CAAA,sBAAA,EAAyBF,CAAM,CAAA,EAAA,CAAA,CACxC,OAAA,CAAS,KACX,CAAC,CAAC,EACF,GAAI,CAACC,GAAAA,CAAS,OACd,IAAME,CAAAA,CAAUC,CAAAA,CAAc,CAAA,SAAA,EAAYJ,CAAM,CAAA,IAAA,CAAM,CAAA,CACtDG,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,sBAAA,CAAwB,CAAE,MAAA,CAAAL,CAAO,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACzEG,CAAAA,CAAQ,OAAA,EAAQ,CAChBG,CAAAA,CAAW,CAAA,UAAA,EAAaN,CAAM,GAAG,EACnC","file":"collab-leave-CR4VOXZV.js","sourcesContent":["import inquirer from 'inquirer'\nimport { 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 collabLeave(folder: string): Promise<void> {\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: `Remove yourself from \"${folder}\"?`,\n default: false,\n }])\n if (!confirm) return\n const spinner = createSpinner(`Leaving \"${folder}\"...`)\n spinner.start()\n await apiPost('/api/v1/collab/leave', { folder }, { authenticated: true })\n spinner.succeed()\n logSuccess(`You left \"${folder}\"`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import {a}from'./chunk-THMWE2I6.js';import {c as c$1}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import t from'chalk';async function n(r){let i=((await c(`/api/v1/collab/list?folder=${encodeURIComponent(r)}`,{authenticated:true})).collaborators||[]).map(e=>({email:e.email,user:e.username,role:t.hex("#7C4DFF")(e.role),joined:c$1(e.joined_at),active:e.last_active?c$1(e.last_active):t.dim("never")}));console.log(a(i,[{key:"email",label:"Email"},{key:"user",label:"User"},{key:"role",label:"Role"},{key:"joined",label:"Joined"},{key:"active",label:"Last Active"}]));}export{n as default};//# sourceMappingURL=collab-list-BHO5IEAR.js.map
2
+ //# sourceMappingURL=collab-list-BHO5IEAR.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/collab/collab-list.ts"],"names":["collabList","folder","rows","apiGet","c","chalk","formatRelative","renderTable"],"mappings":"qNAaA,eAAOA,CAAAA,CAAkCC,EAA+B,CAEtE,IAAMC,IADO,MAAMC,CAAAA,CAA0C,8BAA8B,kBAAA,CAAmBF,CAAM,CAAC,CAAA,CAAA,CAAI,CAAE,cAAe,IAAK,CAAC,GAC7H,aAAA,EAAiB,IAAI,GAAA,CAAIG,CAAAA,GAAM,CAChD,KAAA,CAAOA,CAAAA,CAAE,MACT,IAAA,CAAMA,CAAAA,CAAE,SACR,IAAA,CAAMC,CAAAA,CAAM,IAAI,SAAS,CAAA,CAAED,EAAE,IAAI,CAAA,CACjC,OAAQE,CAAAA,CAAeF,CAAAA,CAAE,SAAS,CAAA,CAClC,MAAA,CAAQA,CAAAA,CAAE,YAAcE,CAAAA,CAAeF,CAAAA,CAAE,WAAW,CAAA,CAAIC,CAAAA,CAAM,IAAI,OAAO,CAC3E,EAAE,CAAA,CACF,OAAA,CAAQ,IAAIE,CAAAA,CAAYL,CAAAA,CAAM,CAC5B,CAAE,GAAA,CAAK,QAAS,KAAA,CAAO,OAAQ,CAAA,CAC/B,CAAE,GAAA,CAAK,MAAA,CAAQ,MAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,MAAA,CAAQ,MAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,QAAA,CAAU,MAAO,QAAS,CAAA,CACjC,CAAE,GAAA,CAAK,QAAA,CAAU,MAAO,aAAc,CACxC,CAAC,CAAC,EACJ","file":"collab-list-JV4ZCWLB.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface Collaborator {\n email: string\n username: string\n role: string\n joined_at: string\n last_active: string | null\n}\n\nexport default async function collabList(folder: string): Promise<void> {\n const data = await apiGet<{ collaborators: Collaborator[] }>(`/api/v1/collab/list?folder=${encodeURIComponent(folder)}`, { authenticated: true })\n const rows = (data.collaborators || []).map(c => ({\n email: c.email,\n user: c.username,\n role: chalk.hex('#7C4DFF')(c.role),\n joined: formatRelative(c.joined_at),\n active: c.last_active ? formatRelative(c.last_active) : chalk.dim('never'),\n }))\n console.log(renderTable(rows, [\n { key: 'email', label: 'Email' },\n { key: 'user', label: 'User' },\n { key: 'role', label: 'Role' },\n { key: 'joined', label: 'Joined' },\n { key: 'active', label: 'Last Active' },\n ]))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/collab/collab-list.ts"],"names":["collabList","folder","rows","apiGet","c","chalk","formatRelative","renderTable"],"mappings":"wPAaA,eAAOA,CAAAA,CAAkCC,EAA+B,CAEtE,IAAMC,IADO,MAAMC,CAAAA,CAA0C,8BAA8B,kBAAA,CAAmBF,CAAM,CAAC,CAAA,CAAA,CAAI,CAAE,cAAe,IAAK,CAAC,GAC7H,aAAA,EAAiB,IAAI,GAAA,CAAIG,CAAAA,GAAM,CAChD,KAAA,CAAOA,CAAAA,CAAE,MACT,IAAA,CAAMA,CAAAA,CAAE,SACR,IAAA,CAAMC,CAAAA,CAAM,IAAI,SAAS,CAAA,CAAED,EAAE,IAAI,CAAA,CACjC,OAAQE,GAAAA,CAAeF,CAAAA,CAAE,SAAS,CAAA,CAClC,MAAA,CAAQA,CAAAA,CAAE,YAAcE,GAAAA,CAAeF,CAAAA,CAAE,WAAW,CAAA,CAAIC,CAAAA,CAAM,IAAI,OAAO,CAC3E,EAAE,CAAA,CACF,OAAA,CAAQ,IAAIE,CAAAA,CAAYL,CAAAA,CAAM,CAC5B,CAAE,GAAA,CAAK,QAAS,KAAA,CAAO,OAAQ,CAAA,CAC/B,CAAE,GAAA,CAAK,MAAA,CAAQ,MAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,MAAA,CAAQ,MAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,QAAA,CAAU,MAAO,QAAS,CAAA,CACjC,CAAE,GAAA,CAAK,QAAA,CAAU,MAAO,aAAc,CACxC,CAAC,CAAC,EACJ","file":"collab-list-BHO5IEAR.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface Collaborator {\n email: string\n username: string\n role: string\n joined_at: string\n last_active: string | null\n}\n\nexport default async function collabList(folder: string): Promise<void> {\n const data = await apiGet<{ collaborators: Collaborator[] }>(`/api/v1/collab/list?folder=${encodeURIComponent(folder)}`, { authenticated: true })\n const rows = (data.collaborators || []).map(c => ({\n email: c.email,\n user: c.username,\n role: chalk.hex('#7C4DFF')(c.role),\n joined: formatRelative(c.joined_at),\n active: c.last_active ? formatRelative(c.last_active) : chalk.dim('never'),\n }))\n console.log(renderTable(rows, [\n { key: 'email', label: 'Email' },\n { key: 'user', label: 'User' },\n { key: 'role', label: 'Role' },\n { key: 'joined', label: 'Joined' },\n { key: 'active', label: 'Last Active' },\n ]))\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';async function o(e,i){let m=a(`Removing ${i.email} from "${e}"...`);m.start(),await d("/api/v1/collab/remove",{folder:e,email:i.email},{authenticated:true}),m.succeed(),g(`Removed ${i.email} from "${e}"`);}export{o as default};//# sourceMappingURL=collab-remove-XI3NX2M7.js.map
2
+ //# sourceMappingURL=collab-remove-XI3NX2M7.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/collab/collab-remove.ts"],"names":["collabRemove","folder","options","spinner","createSpinner","apiPost","logSuccess"],"mappings":"gMAIA,eAAOA,EAAoCC,GAAAA,CAAgBC,CAAAA,CAA2C,CACpG,IAAMC,CAAAA,CAAUC,EAAc,CAAA,SAAA,EAAYF,CAAAA,CAAQ,KAAK,CAAA,OAAA,EAAUD,GAAM,MAAM,CAAA,CAC7EE,CAAAA,CAAQ,OAAM,CACd,MAAME,EAAQ,uBAAA,CAAyB,CAAE,MAAA,CAAAJ,GAAAA,CAAQ,MAAOC,CAAAA,CAAQ,KAAM,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAChGC,EAAQ,OAAA,EAAQ,CAChBG,EAAW,CAAA,QAAA,EAAWJ,CAAAA,CAAQ,KAAK,CAAA,OAAA,EAAUD,GAAM,GAAG,EACxD","file":"collab-remove-DO4BIA5R.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 collabRemove(folder: string, options: { email: string }): Promise<void> {\n const spinner = createSpinner(`Removing ${options.email} from \"${folder}\"...`)\n spinner.start()\n await apiPost('/api/v1/collab/remove', { folder, email: options.email }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Removed ${options.email} from \"${folder}\"`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/collab/collab-remove.ts"],"names":["collabRemove","folder","options","spinner","createSpinner","apiPost","logSuccess"],"mappings":"4NAIA,eAAOA,EAAoCC,CAAAA,CAAgBC,CAAAA,CAA2C,CACpG,IAAMC,CAAAA,CAAUC,EAAc,CAAA,SAAA,EAAYF,CAAAA,CAAQ,KAAK,CAAA,OAAA,EAAUD,CAAM,MAAM,CAAA,CAC7EE,CAAAA,CAAQ,OAAM,CACd,MAAME,EAAQ,uBAAA,CAAyB,CAAE,MAAA,CAAAJ,CAAAA,CAAQ,MAAOC,CAAAA,CAAQ,KAAM,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAChGC,EAAQ,OAAA,EAAQ,CAChBG,EAAW,CAAA,QAAA,EAAWJ,CAAAA,CAAQ,KAAK,CAAA,OAAA,EAAUD,CAAM,GAAG,EACxD","file":"collab-remove-XI3NX2M7.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 collabRemove(folder: string, options: { email: string }): Promise<void> {\n const spinner = createSpinner(`Removing ${options.email} from \"${folder}\"...`)\n spinner.start()\n await apiPost('/api/v1/collab/remove', { folder, email: options.email }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Removed ${options.email} from \"${folder}\"`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.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=a(`Transferring ownership of "${r}" to ${t.to}...`);e.start(),await d("/api/v1/collab/transfer",{folder:r,new_owner:t.to},{authenticated:true}),e.succeed(),g(`Ownership of "${r}" transferred to ${t.to}`);}export{m as default};//# sourceMappingURL=collab-transfer-U4XXODAN.js.map
2
+ //# sourceMappingURL=collab-transfer-U4XXODAN.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/collab/collab-transfer.ts"],"names":["collabTransfer","folder","options","confirm","inquirer","v","spinner","createSpinner","apiPost","logSuccess"],"mappings":"wNAKA,eAAOA,CAAAA,CAAsCC,CAAAA,CAAgBC,EAAwC,CACnG,GAAM,CAAE,OAAA,CAAAC,CAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,OAAA,CACN,IAAA,CAAM,UACN,OAAA,CAAS,CAAA,MAAA,EAASH,CAAM,CAAA,mCAAA,EAAsCC,EAAQ,EAAE,CAAA,CAAA,CAAA,CACxE,QAAA,CAAWG,CAAAA,EAAcA,IAAMJ,CAAAA,CAAS,IAAA,CAAO,uCACjD,CAAC,CAAC,EACF,GAAIE,CAAAA,GAAYF,CAAAA,CAAQ,OAExB,IAAMK,GAAAA,CAAUC,CAAAA,CAAc,CAAA,2BAAA,EAA8BN,CAAM,QAAQC,CAAAA,CAAQ,EAAE,CAAA,GAAA,CAAK,CAAA,CACzFI,IAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,yBAAA,CAA2B,CAAE,MAAA,CAAAP,CAAAA,CAAQ,SAAA,CAAWC,CAAAA,CAAQ,EAAG,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACnGI,GAAAA,CAAQ,OAAA,EAAQ,CAChBG,EAAW,CAAA,cAAA,EAAiBR,CAAM,oBAAoBC,CAAAA,CAAQ,EAAE,EAAE,EACpE","file":"collab-transfer-6CG5PHVC.js","sourcesContent":["import inquirer from 'inquirer'\nimport { 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 collabTransfer(folder: string, options: { to: string }): Promise<void> {\n const { confirm } = await inquirer.prompt([{\n type: 'input',\n name: 'confirm',\n message: `Type \"${folder}\" to confirm ownership transfer to ${options.to}:`,\n validate: (v: string) => v === folder ? true : 'Type the exact folder name to confirm',\n }])\n if (confirm !== folder) return\n\n const spinner = createSpinner(`Transferring ownership of \"${folder}\" to ${options.to}...`)\n spinner.start()\n await apiPost('/api/v1/collab/transfer', { folder, new_owner: options.to }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Ownership of \"${folder}\" transferred to ${options.to}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/collab/collab-transfer.ts"],"names":["collabTransfer","folder","options","confirm","inquirer","v","spinner","createSpinner","apiPost","logSuccess"],"mappings":"oPAKA,eAAOA,CAAAA,CAAsCC,CAAAA,CAAgBC,EAAwC,CACnG,GAAM,CAAE,OAAA,CAAAC,GAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,OAAA,CACN,IAAA,CAAM,UACN,OAAA,CAAS,CAAA,MAAA,EAASH,CAAM,CAAA,mCAAA,EAAsCC,EAAQ,EAAE,CAAA,CAAA,CAAA,CACxE,QAAA,CAAWG,CAAAA,EAAcA,IAAMJ,CAAAA,CAAS,IAAA,CAAO,uCACjD,CAAC,CAAC,EACF,GAAIE,GAAAA,GAAYF,CAAAA,CAAQ,OAExB,IAAMK,CAAAA,CAAUC,CAAAA,CAAc,CAAA,2BAAA,EAA8BN,CAAM,QAAQC,CAAAA,CAAQ,EAAE,CAAA,GAAA,CAAK,CAAA,CACzFI,EAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,yBAAA,CAA2B,CAAE,MAAA,CAAAP,CAAAA,CAAQ,SAAA,CAAWC,CAAAA,CAAQ,EAAG,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACnGI,CAAAA,CAAQ,OAAA,EAAQ,CAChBG,EAAW,CAAA,cAAA,EAAiBR,CAAM,oBAAoBC,CAAAA,CAAQ,EAAE,EAAE,EACpE","file":"collab-transfer-U4XXODAN.js","sourcesContent":["import inquirer from 'inquirer'\nimport { 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 collabTransfer(folder: string, options: { to: string }): Promise<void> {\n const { confirm } = await inquirer.prompt([{\n type: 'input',\n name: 'confirm',\n message: `Type \"${folder}\" to confirm ownership transfer to ${options.to}:`,\n validate: (v: string) => v === folder ? true : 'Type the exact folder name to confirm',\n }])\n if (confirm !== folder) return\n\n const spinner = createSpinner(`Transferring ownership of \"${folder}\" to ${options.to}...`)\n spinner.start()\n await apiPost('/api/v1/collab/transfer', { folder, new_owner: options.to }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Ownership of \"${folder}\" transferred to ${options.to}`)\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import {a as a$1}from'./chunk-MKRWNV2T.js';import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {h as h$1,i,f,m,g,c,b}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.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$1,e){let a$2=d$1?h.resolve(d$1):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?.name,environment:e?.env||(e?.preview?"preview":"production"),force:e?.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?.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 d("/api/v1/deploy",l,{authenticated:!0});r.succeed();let i=o.url||`https://squidcloud.vercel.app/sites/${e?.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-5AQMGJ2Q.js.map
3
+ //# sourceMappingURL=deploy-5AQMGJ2Q.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/lib/deploy/detector.ts","../src/commands/deploy/index.ts"],"names":["detectProject","targetPath","resolved","path","stat","fs","walk","dir","entries","entry","fullPath","totalFiles","htmlFiles","hasIndexHtml","f","deploy","target","options","deployPath","spinner","createSpinner","project","logError","logWarn","deployOptions","isAllowedFile","allowedFiles","ignoredFiles","progressBar","cliProgress","chalk","formData","uploadedCount","filePath","relativePath","content","blob","result","apiPost","siteUrl","clipboard","isJsonMode","logJSON","logSuccess","copied","muted","err"],"mappings":"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","file":"deploy-X5HX7V4J.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\n\nexport type DeployType = 'single-file' | 'codebase' | 'invalid'\n\nexport interface DetectedProject {\n type: DeployType\n rootPath: string\n hasIndexHtml: boolean\n htmlFiles: string[]\n totalFiles: number\n}\n\nexport async function detectProject(targetPath: string): Promise<DetectedProject> {\n const resolved = path.resolve(targetPath)\n const stat = fs.statSync(resolved)\n\n if (stat.isFile()) {\n const ext = path.extname(resolved).toLowerCase()\n if (ext === '.html') {\n return {\n type: 'single-file',\n rootPath: resolved,\n hasIndexHtml: true,\n htmlFiles: [resolved],\n totalFiles: 1,\n }\n }\n return { type: 'invalid', rootPath: resolved, hasIndexHtml: false, htmlFiles: [], totalFiles: 0 }\n }\n\n if (stat.isDirectory()) {\n const htmlFiles: string[] = []\n let totalFiles = 0\n\n function walk(dir: 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 if (entry.isDirectory()) {\n if (!entry.name.startsWith('.') && entry.name !== 'node_modules') {\n walk(fullPath)\n }\n } else if (entry.isFile()) {\n totalFiles++\n if (entry.name.endsWith('.html')) {\n htmlFiles.push(fullPath)\n }\n }\n }\n }\n\n walk(resolved)\n\n if (htmlFiles.length === 0) {\n return { type: 'invalid', rootPath: resolved, hasIndexHtml: false, htmlFiles: [], totalFiles }\n }\n\n const hasIndexHtml = htmlFiles.some(f => path.basename(f).toLowerCase() === 'index.html')\n\n return {\n type: 'codebase',\n rootPath: resolved,\n hasIndexHtml,\n htmlFiles,\n totalFiles,\n }\n }\n\n return { type: 'invalid', rootPath: resolved, hasIndexHtml: false, htmlFiles: [], totalFiles: 0 }\n}\n","import path from 'node:path'\nimport fs from 'node:fs'\nimport { detectProject, isAllowedFile } from '../../lib/deploy/index.js'\nimport { apiPost, apiUpload } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logError, logInfo, logJSON, logWarn } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatBytes } from '../../lib/utils/format.js'\nimport clipboard from 'clipboardy'\nimport chalk from 'chalk'\nimport { copied, muted } from '../../lib/output/brand.js'\nimport cliProgress from 'cli-progress'\n\nexport default async function deploy(target?: string, options?: {\n name?: string\n env?: string\n preview?: boolean\n noWait?: boolean\n force?: boolean\n output?: string\n}): Promise<void> {\n const deployPath = target ? path.resolve(target) : process.cwd()\n\n const spinner = createSpinner('Analyzing project...')\n spinner.start()\n\n const project = await detectProject(deployPath)\n\n if (project.type === 'invalid') {\n spinner.fail()\n logError(`No deployable content found at ${deployPath}. Provide an HTML file or folder containing HTML files.`)\n process.exit(1)\n }\n\n if (project.type === 'codebase' && !project.hasIndexHtml) {\n spinner.warn()\n logWarn('No index.html found at root. Scanning one level deep for entry point...')\n }\n\n spinner.text = 'Uploading files...'\n\n const deployOptions: Record<string, unknown> = {\n source: deployPath,\n type: project.type,\n slug: options?.name,\n environment: options?.env || (options?.preview ? 'preview' : 'production'),\n force: options?.force || false,\n }\n\n if (project.type === 'codebase') {\n const files: { path: string; content: string }[] = []\n const allowedFiles: string[] = []\n const ignoredFiles: string[] = []\n\n function walk(dir: 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 if (entry.isDirectory()) {\n if (!entry.name.startsWith('.') && entry.name !== 'node_modules') {\n walk(fullPath)\n }\n } else if (entry.isFile()) {\n if (isAllowedFile(entry.name)) {\n allowedFiles.push(fullPath)\n } else {\n ignoredFiles.push(fullPath)\n }\n }\n }\n }\n\n walk(project.rootPath)\n\n if (!options?.force && project.type === 'codebase') {\n spinner.text = 'Computing diff...'\n }\n\n const progressBar = new cliProgress.SingleBar({\n format: `${chalk.hex('#7C4DFF')('▸')} Uploading |${chalk.hex('#7C4DFF')('{bar}')}| {percentage}% | {value}/{total} files | {speed}`,\n barCompleteChar: '█',\n barIncompleteChar: '░',\n hideCursor: true,\n })\n\n progressBar.start(allowedFiles.length, 0)\n\n const formData = new FormData()\n let uploadedCount = 0\n\n for (const filePath of allowedFiles) {\n const relativePath = path.relative(project.rootPath, filePath)\n const content = fs.readFileSync(filePath)\n const blob = new Blob([content])\n formData.append('files', blob, relativePath)\n uploadedCount++\n progressBar.update(uploadedCount)\n }\n\n progressBar.stop()\n spinner.stop()\n\n deployOptions.files = formData\n }\n\n if (project.type === 'single-file') {\n const content = fs.readFileSync(project.rootPath, 'utf-8')\n deployOptions.htmlContent = content\n }\n\n spinner.text = 'Deploying to SquidCloud...'\n spinner.start()\n\n try {\n const result = await apiPost<{\n url: string\n deploy_id: string\n file_count: number\n deploy_time_ms: number\n }>('/api/v1/deploy', deployOptions, { authenticated: true })\n\n spinner.succeed()\n\n const siteUrl = result.url || `https://squidcloud.vercel.app/sites/${options?.name || result.deploy_id}`\n\n try {\n await clipboard.write(siteUrl)\n } catch {\n // clipboard not available\n }\n\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n\n logSuccess(`Deployed successfully!`)\n console.log(` ${chalk.hex('#4FC3F7')(siteUrl)} ${copied('')}`)\n if (result.file_count) {\n console.log(` ${muted(`${result.file_count} files · ${result.deploy_time_ms}ms`)}`)\n }\n } catch (err) {\n spinner.fail()\n throw err\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/lib/deploy/detector.ts","../src/commands/deploy/index.ts"],"names":["detectProject","targetPath","resolved","path","stat","fs","walk","dir","entries","entry","fullPath","totalFiles","htmlFiles","hasIndexHtml","f","deploy","target","options","deployPath","spinner","createSpinner","project","logError","logWarn","deployOptions","isAllowedFile","allowedFiles","ignoredFiles","progressBar","cliProgress","chalk","formData","uploadedCount","filePath","relativePath","content","blob","result","apiPost","siteUrl","clipboard","isJsonMode","logJSON","logSuccess","copied","muted","err"],"mappings":"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","file":"deploy-5AQMGJ2Q.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\n\nexport type DeployType = 'single-file' | 'codebase' | 'invalid'\n\nexport interface DetectedProject {\n type: DeployType\n rootPath: string\n hasIndexHtml: boolean\n htmlFiles: string[]\n totalFiles: number\n}\n\nexport async function detectProject(targetPath: string): Promise<DetectedProject> {\n const resolved = path.resolve(targetPath)\n const stat = fs.statSync(resolved)\n\n if (stat.isFile()) {\n const ext = path.extname(resolved).toLowerCase()\n if (ext === '.html') {\n return {\n type: 'single-file',\n rootPath: resolved,\n hasIndexHtml: true,\n htmlFiles: [resolved],\n totalFiles: 1,\n }\n }\n return { type: 'invalid', rootPath: resolved, hasIndexHtml: false, htmlFiles: [], totalFiles: 0 }\n }\n\n if (stat.isDirectory()) {\n const htmlFiles: string[] = []\n let totalFiles = 0\n\n function walk(dir: 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 if (entry.isDirectory()) {\n if (!entry.name.startsWith('.') && entry.name !== 'node_modules') {\n walk(fullPath)\n }\n } else if (entry.isFile()) {\n totalFiles++\n if (entry.name.endsWith('.html')) {\n htmlFiles.push(fullPath)\n }\n }\n }\n }\n\n walk(resolved)\n\n if (htmlFiles.length === 0) {\n return { type: 'invalid', rootPath: resolved, hasIndexHtml: false, htmlFiles: [], totalFiles }\n }\n\n const hasIndexHtml = htmlFiles.some(f => path.basename(f).toLowerCase() === 'index.html')\n\n return {\n type: 'codebase',\n rootPath: resolved,\n hasIndexHtml,\n htmlFiles,\n totalFiles,\n }\n }\n\n return { type: 'invalid', rootPath: resolved, hasIndexHtml: false, htmlFiles: [], totalFiles: 0 }\n}\n","import path from 'node:path'\nimport fs from 'node:fs'\nimport { detectProject, isAllowedFile } from '../../lib/deploy/index.js'\nimport { apiPost, apiUpload } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logError, logInfo, logJSON, logWarn } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatBytes } from '../../lib/utils/format.js'\nimport clipboard from 'clipboardy'\nimport chalk from 'chalk'\nimport { copied, muted } from '../../lib/output/brand.js'\nimport cliProgress from 'cli-progress'\n\nexport default async function deploy(target?: string, options?: {\n name?: string\n env?: string\n preview?: boolean\n noWait?: boolean\n force?: boolean\n output?: string\n}): Promise<void> {\n const deployPath = target ? path.resolve(target) : process.cwd()\n\n const spinner = createSpinner('Analyzing project...')\n spinner.start()\n\n const project = await detectProject(deployPath)\n\n if (project.type === 'invalid') {\n spinner.fail()\n logError(`No deployable content found at ${deployPath}. Provide an HTML file or folder containing HTML files.`)\n process.exit(1)\n }\n\n if (project.type === 'codebase' && !project.hasIndexHtml) {\n spinner.warn()\n logWarn('No index.html found at root. Scanning one level deep for entry point...')\n }\n\n spinner.text = 'Uploading files...'\n\n const deployOptions: Record<string, unknown> = {\n source: deployPath,\n type: project.type,\n slug: options?.name,\n environment: options?.env || (options?.preview ? 'preview' : 'production'),\n force: options?.force || false,\n }\n\n if (project.type === 'codebase') {\n const files: { path: string; content: string }[] = []\n const allowedFiles: string[] = []\n const ignoredFiles: string[] = []\n\n function walk(dir: 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 if (entry.isDirectory()) {\n if (!entry.name.startsWith('.') && entry.name !== 'node_modules') {\n walk(fullPath)\n }\n } else if (entry.isFile()) {\n if (isAllowedFile(entry.name)) {\n allowedFiles.push(fullPath)\n } else {\n ignoredFiles.push(fullPath)\n }\n }\n }\n }\n\n walk(project.rootPath)\n\n if (!options?.force && project.type === 'codebase') {\n spinner.text = 'Computing diff...'\n }\n\n const progressBar = new cliProgress.SingleBar({\n format: `${chalk.hex('#7C4DFF')('▸')} Uploading |${chalk.hex('#7C4DFF')('{bar}')}| {percentage}% | {value}/{total} files | {speed}`,\n barCompleteChar: '█',\n barIncompleteChar: '░',\n hideCursor: true,\n })\n\n progressBar.start(allowedFiles.length, 0)\n\n const formData = new FormData()\n let uploadedCount = 0\n\n for (const filePath of allowedFiles) {\n const relativePath = path.relative(project.rootPath, filePath)\n const content = fs.readFileSync(filePath)\n const blob = new Blob([content])\n formData.append('files', blob, relativePath)\n uploadedCount++\n progressBar.update(uploadedCount)\n }\n\n progressBar.stop()\n spinner.stop()\n\n deployOptions.files = formData\n }\n\n if (project.type === 'single-file') {\n const content = fs.readFileSync(project.rootPath, 'utf-8')\n deployOptions.htmlContent = content\n }\n\n spinner.text = 'Deploying to SquidCloud...'\n spinner.start()\n\n try {\n const result = await apiPost<{\n url: string\n deploy_id: string\n file_count: number\n deploy_time_ms: number\n }>('/api/v1/deploy', deployOptions, { authenticated: true })\n\n spinner.succeed()\n\n const siteUrl = result.url || `https://squidcloud.vercel.app/sites/${options?.name || result.deploy_id}`\n\n try {\n await clipboard.write(siteUrl)\n } catch {\n // clipboard not available\n }\n\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n\n logSuccess(`Deployed successfully!`)\n console.log(` ${chalk.hex('#4FC3F7')(siteUrl)} ${copied('')}`)\n if (result.file_count) {\n console.log(` ${muted(`${result.file_count} files · ${result.deploy_time_ms}ms`)}`)\n }\n } catch (err) {\n spinner.fail()\n throw err\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {c as c$1}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import {d as d$1,c}from'./chunk-W6CRHANC.js';import e from'chalk';async function d(m$1){let t=[];parseInt(process.version.slice(1),10)>=20?t.push({name:"Node.js Version",status:"pass",message:`${process.version} (20+ required)`}):t.push({name:"Node.js Version",status:"fail",message:`${process.version} \u2014 upgrade to 20+`});let o=await d$1();if(o){let a=o.device_fingerprint===c();t.push({name:"Auth Session",status:a?"pass":"warn",message:a?`Authenticated as ${o.user.email}`:"Device fingerprint mismatch \u2014 may need re-login"});}else t.push({name:"Auth Session",status:"warn",message:"Not authenticated \u2014 run `squidcloud login`"});try{await c$1("/api/health"),t.push({name:"Network",status:"pass",message:"Connected to SquidCloud API"});}catch{t.push({name:"Network",status:"fail",message:"Cannot reach SquidCloud API"});}if(m$1?.security){t.push({name:"Device Fingerprint",status:"pass",message:c().slice(0,16)+"..."});try{let a=await c$1("/api/auth/ssp/security-check",{authenticated:!0});t.push({name:"Server Security",status:"pass",message:"All checks passed"});}catch{t.push({name:"Server Security",status:"warn",message:"Could not verify all security checks"});}}if(f()){m({checks:t});return}l(""),l(e.bold(" SquidCloud Diagnostics")),l(e.dim(" \u2500\u2500\u2500".repeat(10))),l("");for(let a of t){let p=a.status==="pass"?e.green("\u2713"):a.status==="warn"?e.yellow("\u26A0"):e.red("\u2717");l(` ${p} ${e.bold(a.name)}`),l(` ${e.dim(a.message)}`),l("");}l(e.bold(" Environment")),l(e.dim(" \u2500\u2500\u2500".repeat(10))),l(""),l(` ${e.dim("Platform:")} ${process.platform} ${process.arch}`),l(` ${e.dim("Node:")} ${process.version}`),l(` ${e.dim("CWD:")} ${process.cwd()}`),l("");}export{d as default};//# sourceMappingURL=doctor-5TK2COIN.js.map
2
+ //# sourceMappingURL=doctor-5TK2COIN.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/util/doctor.ts"],"names":["doctor","options","checks","session","loadSession","fpMatch","computeDeviceFingerprint","apiGet","securityInfo","isJsonMode","logJSON","logRaw","chalk","check","icon"],"mappings":"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","file":"doctor-RSKBJYUX.js","sourcesContent":["import envinfo from 'envinfo'\nimport chalk from 'chalk'\nimport { loadSession } from '../../lib/auth/session.js'\nimport { computeDeviceFingerprint } from '../../lib/auth/fingerprint.js'\nimport { apiGet } from '../../lib/api/client.js'\nimport { logSuccess, logError, logInfo, logJSON, logRaw } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\n\nexport default async function doctor(options?: { security?: boolean }): Promise<void> {\n const checks: { name: string; status: 'pass' | 'fail' | 'warn'; message: string }[] = []\n\n // Node version check\n const nodeMajor = parseInt(process.version.slice(1), 10)\n if (nodeMajor >= 20) {\n checks.push({ name: 'Node.js Version', status: 'pass', message: `${process.version} (20+ required)` })\n } else {\n checks.push({ name: 'Node.js Version', status: 'fail', message: `${process.version} — upgrade to 20+` })\n }\n\n // Auth check\n const session = await loadSession()\n if (session) {\n const fpMatch = session.device_fingerprint === computeDeviceFingerprint()\n checks.push({\n name: 'Auth Session',\n status: fpMatch ? 'pass' : 'warn',\n message: fpMatch ? `Authenticated as ${session.user.email}` : 'Device fingerprint mismatch — may need re-login',\n })\n } else {\n checks.push({ name: 'Auth Session', status: 'warn', message: 'Not authenticated — run `squidcloud login`' })\n }\n\n // Network connectivity\n try {\n await apiGet('/api/health')\n checks.push({ name: 'Network', status: 'pass', message: 'Connected to SquidCloud API' })\n } catch {\n checks.push({ name: 'Network', status: 'fail', message: 'Cannot reach SquidCloud API' })\n }\n\n if (options?.security) {\n checks.push({\n name: 'Device Fingerprint',\n status: 'pass',\n message: computeDeviceFingerprint().slice(0, 16) + '...',\n })\n try {\n const securityInfo = await apiGet('/api/auth/ssp/security-check', { authenticated: true })\n checks.push({ name: 'Server Security', status: 'pass', message: 'All checks passed' })\n } catch {\n checks.push({ name: 'Server Security', status: 'warn', message: 'Could not verify all security checks' })\n }\n }\n\n if (isJsonMode()) {\n logJSON({ checks })\n return\n }\n\n logRaw('')\n logRaw(chalk.bold(' SquidCloud Diagnostics'))\n logRaw(chalk.dim(' ───'.repeat(10)))\n logRaw('')\n\n for (const check of checks) {\n const icon = check.status === 'pass' ? chalk.green('✓') : check.status === 'warn' ? chalk.yellow('⚠') : chalk.red('✗')\n logRaw(` ${icon} ${chalk.bold(check.name)}`)\n logRaw(` ${chalk.dim(check.message)}`)\n logRaw('')\n }\n\n logRaw(chalk.bold(' Environment'))\n logRaw(chalk.dim(' ───'.repeat(10)))\n logRaw('')\n logRaw(` ${chalk.dim('Platform:')} ${process.platform} ${process.arch}`)\n logRaw(` ${chalk.dim('Node:')} ${process.version}`)\n logRaw(` ${chalk.dim('CWD:')} ${process.cwd()}`)\n logRaw('')\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/util/doctor.ts"],"names":["doctor","options","checks","session","loadSession","fpMatch","computeDeviceFingerprint","apiGet","securityInfo","isJsonMode","logJSON","logRaw","chalk","check","icon"],"mappings":"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","file":"doctor-5TK2COIN.js","sourcesContent":["import envinfo from 'envinfo'\nimport chalk from 'chalk'\nimport { loadSession } from '../../lib/auth/session.js'\nimport { computeDeviceFingerprint } from '../../lib/auth/fingerprint.js'\nimport { apiGet } from '../../lib/api/client.js'\nimport { logSuccess, logError, logInfo, logJSON, logRaw } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\n\nexport default async function doctor(options?: { security?: boolean }): Promise<void> {\n const checks: { name: string; status: 'pass' | 'fail' | 'warn'; message: string }[] = []\n\n // Node version check\n const nodeMajor = parseInt(process.version.slice(1), 10)\n if (nodeMajor >= 20) {\n checks.push({ name: 'Node.js Version', status: 'pass', message: `${process.version} (20+ required)` })\n } else {\n checks.push({ name: 'Node.js Version', status: 'fail', message: `${process.version} — upgrade to 20+` })\n }\n\n // Auth check\n const session = await loadSession()\n if (session) {\n const fpMatch = session.device_fingerprint === computeDeviceFingerprint()\n checks.push({\n name: 'Auth Session',\n status: fpMatch ? 'pass' : 'warn',\n message: fpMatch ? `Authenticated as ${session.user.email}` : 'Device fingerprint mismatch — may need re-login',\n })\n } else {\n checks.push({ name: 'Auth Session', status: 'warn', message: 'Not authenticated — run `squidcloud login`' })\n }\n\n // Network connectivity\n try {\n await apiGet('/api/health')\n checks.push({ name: 'Network', status: 'pass', message: 'Connected to SquidCloud API' })\n } catch {\n checks.push({ name: 'Network', status: 'fail', message: 'Cannot reach SquidCloud API' })\n }\n\n if (options?.security) {\n checks.push({\n name: 'Device Fingerprint',\n status: 'pass',\n message: computeDeviceFingerprint().slice(0, 16) + '...',\n })\n try {\n const securityInfo = await apiGet('/api/auth/ssp/security-check', { authenticated: true })\n checks.push({ name: 'Server Security', status: 'pass', message: 'All checks passed' })\n } catch {\n checks.push({ name: 'Server Security', status: 'warn', message: 'Could not verify all security checks' })\n }\n }\n\n if (isJsonMode()) {\n logJSON({ checks })\n return\n }\n\n logRaw('')\n logRaw(chalk.bold(' SquidCloud Diagnostics'))\n logRaw(chalk.dim(' ───'.repeat(10)))\n logRaw('')\n\n for (const check of checks) {\n const icon = check.status === 'pass' ? chalk.green('✓') : check.status === 'warn' ? chalk.yellow('⚠') : chalk.red('✗')\n logRaw(` ${icon} ${chalk.bold(check.name)}`)\n logRaw(` ${chalk.dim(check.message)}`)\n logRaw('')\n }\n\n logRaw(chalk.bold(' Environment'))\n logRaw(chalk.dim(' ───'.repeat(10)))\n logRaw('')\n logRaw(` ${chalk.dim('Platform:')} ${process.platform} ${process.arch}`)\n logRaw(` ${chalk.dim('Node:')} ${process.version}`)\n logRaw(` ${chalk.dim('CWD:')} ${process.cwd()}`)\n logRaw('')\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {f}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.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 f(`/api/v1/forms/${o}/submissions`,{authenticated:true}),e.succeed(),g("All submissions cleared");}export{m as default};//# sourceMappingURL=forms-clear-4BQMLGGN.js.map
2
+ //# sourceMappingURL=forms-clear-4BQMLGGN.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-clear.ts"],"names":["formsClear","id","confirm","inquirer","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"+NAKA,eAAOA,CAAAA,CAAkCC,CAAAA,CAA2B,CAClE,GAAM,CAAE,OAAA,CAAAC,CAAQ,CAAA,CAAI,MAAMC,EAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,SAAA,CACN,IAAA,CAAM,SAAA,CACN,OAAA,CAAS,sEAAA,CACT,OAAA,CAAS,KACX,CAAC,CAAC,CAAA,CACF,GAAI,CAACD,CAAAA,CAAS,OACd,IAAME,CAAAA,CAAUC,CAAAA,CAAc,yBAAyB,CAAA,CACvDD,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAU,iBAAiBL,CAAE,CAAA,YAAA,CAAA,CAAgB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC1EG,CAAAA,CAAQ,OAAA,EAAQ,CAChBG,GAAAA,CAAW,yBAAyB,EACtC","file":"forms-clear-UJ23UHUN.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 formsClear(id: string): Promise<void> {\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: 'Delete ALL submissions for this file request? This cannot be undone.',\n default: false,\n }])\n if (!confirm) return\n const spinner = createSpinner('Clearing submissions...')\n spinner.start()\n await apiDelete(`/api/v1/forms/${id}/submissions`, { authenticated: true })\n spinner.succeed()\n logSuccess('All submissions cleared')\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-clear.ts"],"names":["formsClear","id","confirm","inquirer","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"oPAKA,eAAOA,CAAAA,CAAkCC,CAAAA,CAA2B,CAClE,GAAM,CAAE,OAAA,CAAAC,CAAQ,CAAA,CAAI,MAAMC,EAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,SAAA,CACN,IAAA,CAAM,SAAA,CACN,OAAA,CAAS,sEAAA,CACT,OAAA,CAAS,KACX,CAAC,CAAC,CAAA,CACF,GAAI,CAACD,CAAAA,CAAS,OACd,IAAME,CAAAA,CAAUC,CAAAA,CAAc,yBAAyB,CAAA,CACvDD,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAU,iBAAiBL,CAAE,CAAA,YAAA,CAAA,CAAgB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC1EG,CAAAA,CAAQ,OAAA,EAAQ,CAChBG,CAAAA,CAAW,yBAAyB,EACtC","file":"forms-clear-4BQMLGGN.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 formsClear(id: string): Promise<void> {\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: 'Delete ALL submissions for this file request? This cannot be undone.',\n default: false,\n }])\n if (!confirm) return\n const spinner = createSpinner('Clearing submissions...')\n spinner.start()\n await apiDelete(`/api/v1/forms/${id}/submissions`, { authenticated: true })\n spinner.succeed()\n logSuccess('All submissions cleared')\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a as a$1}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {f,m,g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';async function a(r,c){let e=a$1(`Creating file request "${r}"...`);e.start();let t=await d("/api/v1/forms",{name:r,folder:c?.folder},{authenticated:true});if(e.succeed(),f()){m(t);return}g(`File request "${r}" created (${t.id.slice(0,8)})`);}export{a as default};//# sourceMappingURL=forms-create-ORURKN5O.js.map
2
+ //# sourceMappingURL=forms-create-ORURKN5O.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-create.ts"],"names":["formsCreate","name","options","spinner","createSpinner","result","apiPost","isJsonMode","logJSON","logSuccess"],"mappings":"oMAKA,eAAOA,CAAAA,CAAmCC,CAAAA,CAAcC,CAAAA,CAA8C,CACpG,IAAMC,IAAUC,CAAAA,CAAc,CAAA,uBAAA,EAA0BH,CAAI,CAAA,IAAA,CAAM,CAAA,CAClEE,GAAAA,CAAQ,OAAM,CACd,IAAME,CAAAA,CAAS,MAAMC,CAAAA,CAAqC,eAAA,CAAiB,CACzE,IAAA,CAAAL,CAAAA,CACA,MAAA,CAAQC,CAAAA,EAAS,MACnB,CAAA,CAAG,CAAE,cAAe,IAAK,CAAC,CAAA,CAG1B,GAFAC,GAAAA,CAAQ,OAAA,GAEJI,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAM,CAAA,CACd,MACF,CACAI,CAAAA,CAAW,CAAA,cAAA,EAAiBR,CAAI,CAAA,WAAA,EAAcI,CAAAA,CAAO,EAAA,CAAG,KAAA,CAAM,CAAA,CAAG,CAAC,CAAC,CAAA,CAAA,CAAG,EACxE","file":"forms-create-CWC7MGOJ.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 formsCreate(name: string, options?: { folder?: string }): Promise<void> {\n const spinner = createSpinner(`Creating file request \"${name}\"...`)\n spinner.start()\n const result = await apiPost<{ id: string; url: string }>('/api/v1/forms', {\n name,\n folder: options?.folder,\n }, { authenticated: true })\n spinner.succeed()\n\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n logSuccess(`File request \"${name}\" created (${result.id.slice(0, 8)})`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-create.ts"],"names":["formsCreate","name","options","spinner","createSpinner","result","apiPost","isJsonMode","logJSON","logSuccess"],"mappings":"uOAKA,eAAOA,CAAAA,CAAmCC,CAAAA,CAAcC,CAAAA,CAA8C,CACpG,IAAMC,EAAUC,GAAAA,CAAc,CAAA,uBAAA,EAA0BH,CAAI,CAAA,IAAA,CAAM,CAAA,CAClEE,CAAAA,CAAQ,OAAM,CACd,IAAME,CAAAA,CAAS,MAAMC,CAAAA,CAAqC,eAAA,CAAiB,CACzE,IAAA,CAAAL,CAAAA,CACA,MAAA,CAAQC,CAAAA,EAAS,MACnB,CAAA,CAAG,CAAE,cAAe,IAAK,CAAC,CAAA,CAG1B,GAFAC,CAAAA,CAAQ,OAAA,GAEJI,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAM,CAAA,CACd,MACF,CACAI,CAAAA,CAAW,CAAA,cAAA,EAAiBR,CAAI,CAAA,WAAA,EAAcI,CAAAA,CAAO,EAAA,CAAG,KAAA,CAAM,CAAA,CAAG,CAAC,CAAC,CAAA,CAAA,CAAG,EACxE","file":"forms-create-ORURKN5O.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 formsCreate(name: string, options?: { folder?: string }): Promise<void> {\n const spinner = createSpinner(`Creating file request \"${name}\"...`)\n spinner.start()\n const result = await apiPost<{ id: string; url: string }>('/api/v1/forms', {\n name,\n folder: options?.folder,\n }, { authenticated: true })\n spinner.succeed()\n\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n logSuccess(`File request \"${name}\" created (${result.id.slice(0, 8)})`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {f}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import s from'inquirer';async function p(t){let e=(await(await import('./client-HD3YWJJJ.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 f(`/api/v1/forms/${t}`,{authenticated:true}),r.succeed(),g(`File request "${e}" deleted`);}export{p as default};//# sourceMappingURL=forms-delete-NT4SAO6G.js.map
2
+ //# sourceMappingURL=forms-delete-NT4SAO6G.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-delete.ts"],"names":["formsDelete","id","formName","confirm","inquirer","v","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"+NAKA,eAAOA,CAAAA,CAAmCC,CAAAA,CAA2B,CAEnE,IAAMC,CAAAA,CAAAA,CADO,KAAA,CAAO,aAAa,sBAAyB,CAAA,EAAG,MAAA,CAAmC,CAAA,cAAA,EAAiBD,CAAE,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACxH,IAAA,CAAK,IAAA,CAErB,CAAE,QAAAE,CAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,OAAO,CAAC,CACzC,KAAM,OAAA,CACN,IAAA,CAAM,UACN,OAAA,CAAS,CAAA,MAAA,EAASF,CAAQ,CAAA,8DAAA,CAAA,CAC1B,SAAWG,CAAAA,EAAcA,CAAAA,GAAMH,CAAAA,CAAW,IAAA,CAAO,gCACnD,CAAC,CAAC,CAAA,CACF,GAAIC,IAAYD,CAAAA,CAAU,OAE1B,IAAMI,CAAAA,CAAUC,CAAAA,CAAc,0BAA0B,CAAA,CACxDD,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAU,CAAA,cAAA,EAAiBP,CAAE,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC9DK,EAAQ,OAAA,EAAQ,CAChBG,IAAW,CAAA,cAAA,EAAiBP,CAAQ,WAAW,EACjD","file":"forms-delete-TKHTM6L5.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 formsDelete(id: string): Promise<void> {\n const data = await (await import('../../lib/api/client.js')).apiGet<{ form: { name: string } }>(`/api/v1/forms/${id}`, { authenticated: true })\n const formName = data.form.name\n\n const { confirm } = await inquirer.prompt([{\n type: 'input',\n name: 'confirm',\n message: `Type \"${formName}\" to permanently delete this file request and all submissions:`,\n validate: (v: string) => v === formName ? true : 'Type the exact name to confirm',\n }])\n if (confirm !== formName) return\n\n const spinner = createSpinner('Deleting file request...')\n spinner.start()\n await apiDelete(`/api/v1/forms/${id}`, { authenticated: true })\n spinner.succeed()\n logSuccess(`File request \"${formName}\" deleted`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-delete.ts"],"names":["formsDelete","id","formName","confirm","inquirer","v","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"oPAKA,eAAOA,CAAAA,CAAmCC,CAAAA,CAA2B,CAEnE,IAAMC,CAAAA,CAAAA,CADO,KAAA,CAAO,aAAa,sBAAyB,CAAA,EAAG,MAAA,CAAmC,CAAA,cAAA,EAAiBD,CAAE,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACxH,IAAA,CAAK,IAAA,CAErB,CAAE,QAAAE,CAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,OAAO,CAAC,CACzC,KAAM,OAAA,CACN,IAAA,CAAM,UACN,OAAA,CAAS,CAAA,MAAA,EAASF,CAAQ,CAAA,8DAAA,CAAA,CAC1B,SAAWG,CAAAA,EAAcA,CAAAA,GAAMH,CAAAA,CAAW,IAAA,CAAO,gCACnD,CAAC,CAAC,CAAA,CACF,GAAIC,IAAYD,CAAAA,CAAU,OAE1B,IAAMI,CAAAA,CAAUC,CAAAA,CAAc,0BAA0B,CAAA,CACxDD,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAU,CAAA,cAAA,EAAiBP,CAAE,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC9DK,EAAQ,OAAA,EAAQ,CAChBG,EAAW,CAAA,cAAA,EAAiBP,CAAQ,WAAW,EACjD","file":"forms-delete-NT4SAO6G.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 formsDelete(id: string): Promise<void> {\n const data = await (await import('../../lib/api/client.js')).apiGet<{ form: { name: string } }>(`/api/v1/forms/${id}`, { authenticated: true })\n const formName = data.form.name\n\n const { confirm } = await inquirer.prompt([{\n type: 'input',\n name: 'confirm',\n message: `Type \"${formName}\" to permanently delete this file request and all submissions:`,\n validate: (v: string) => v === formName ? true : 'Type the exact name to confirm',\n }])\n if (confirm !== formName) return\n\n const spinner = createSpinner('Deleting file request...')\n spinner.start()\n await apiDelete(`/api/v1/forms/${id}`, { authenticated: true })\n spinner.succeed()\n logSuccess(`File request \"${formName}\" deleted`)\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-W6CRHANC.js';import r from'chalk';import m from'clipboardy';async function a(i){let o=await c(`/api/v1/forms/${i}/embed`,{authenticated:true});try{await m.write(o.html);}catch{}console.log(o.html),console.log(r.dim(`
2
+ (copied to clipboard)`));}export{a as default};//# sourceMappingURL=forms-embed-5L4DHGXC.js.map
3
+ //# sourceMappingURL=forms-embed-5L4DHGXC.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-embed.ts"],"names":["formsEmbed","id","data","apiGet","clipboard","chalk"],"mappings":"2IAKA,eAAOA,EAAkCC,CAAAA,CAA2B,CAClE,IAAMC,CAAAA,CAAO,MAAMC,CAAAA,CAAyB,CAAA,cAAA,EAAiBF,CAAE,CAAA,MAAA,CAAA,CAAU,CAAE,cAAe,IAAK,CAAC,CAAA,CAChG,GAAI,CACF,MAAMG,CAAAA,CAAU,MAAMF,CAAAA,CAAK,IAAI,EACjC,CAAA,KAAQ,CAER,CACA,OAAA,CAAQ,IAAIA,CAAAA,CAAK,IAAI,EACrB,OAAA,CAAQ,GAAA,CAAIG,EAAM,GAAA,CAAI;AAAA,qBAAA,CAAyB,CAAC,EAClD","file":"forms-embed-FF3VMR4M.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport chalk from 'chalk'\nimport clipboard from 'clipboardy'\nimport { copied } from '../../lib/output/brand.js'\n\nexport default async function formsEmbed(id: string): Promise<void> {\n const data = await apiGet<{ html: string }>(`/api/v1/forms/${id}/embed`, { authenticated: true })\n try {\n await clipboard.write(data.html)\n } catch {\n // ignore\n }\n console.log(data.html)\n console.log(chalk.dim(`\\n(copied to clipboard)`))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-embed.ts"],"names":["formsEmbed","id","data","apiGet","clipboard","chalk"],"mappings":"uKAKA,eAAOA,EAAkCC,CAAAA,CAA2B,CAClE,IAAMC,CAAAA,CAAO,MAAMC,CAAAA,CAAyB,CAAA,cAAA,EAAiBF,CAAE,CAAA,MAAA,CAAA,CAAU,CAAE,cAAe,IAAK,CAAC,CAAA,CAChG,GAAI,CACF,MAAMG,CAAAA,CAAU,MAAMF,CAAAA,CAAK,IAAI,EACjC,CAAA,KAAQ,CAER,CACA,OAAA,CAAQ,IAAIA,CAAAA,CAAK,IAAI,EACrB,OAAA,CAAQ,GAAA,CAAIG,EAAM,GAAA,CAAI;AAAA,qBAAA,CAAyB,CAAC,EAClD","file":"forms-embed-5L4DHGXC.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport chalk from 'chalk'\nimport clipboard from 'clipboardy'\nimport { copied } from '../../lib/output/brand.js'\n\nexport default async function formsEmbed(id: string): Promise<void> {\n const data = await apiGet<{ html: string }>(`/api/v1/forms/${id}/embed`, { authenticated: true })\n try {\n await clipboard.write(data.html)\n } catch {\n // ignore\n }\n console.log(data.html)\n console.log(chalk.dim(`\\n(copied to clipboard)`))\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import n from'fs';import p from'path';async function m(t){let o=a("Exporting submissions...");o.start();let c$1=await c(`/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$1.csv,"utf-8"),g(`Exported to ${s}`);}export{m as default};//# sourceMappingURL=forms-export-5SDRUFV3.js.map
2
+ //# sourceMappingURL=forms-export-5SDRUFV3.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-export.ts"],"names":["formsExport","id","spinner","createSpinner","data","apiGet","filePath","path","fs","logSuccess"],"mappings":"sOAMA,eAAOA,CAAAA,CAAmCC,CAAAA,CAA2B,CACnE,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,0BAA0B,CAAA,CACxDD,CAAAA,CAAQ,KAAA,EAAM,CACd,IAAME,CAAAA,CAAO,MAAMC,CAAAA,CAAwB,CAAA,cAAA,EAAiBJ,CAAE,CAAA,OAAA,CAAA,CAAW,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAChGC,EAAQ,OAAA,EAAQ,CAChB,IAAMI,CAAAA,CAAWC,CAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,EAAI,CAAG,CAAA,QAAA,EAAWN,CAAAA,CAAG,KAAA,CAAM,CAAA,CAAG,CAAC,CAAC,CAAA,gBAAA,CAAkB,CAAA,CACrFO,CAAAA,CAAG,aAAA,CAAcF,CAAAA,CAAUF,CAAAA,CAAK,GAAA,CAAK,OAAO,CAAA,CAC5CK,CAAAA,CAAW,CAAA,YAAA,EAAeH,CAAQ,CAAA,CAAE,EACtC","file":"forms-export-5ZNEL3V2.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 formsExport(id: string): Promise<void> {\n const spinner = createSpinner('Exporting submissions...')\n spinner.start()\n const data = await apiGet<{ csv: string }>(`/api/v1/forms/${id}/export`, { authenticated: true })\n spinner.succeed()\n const filePath = path.join(process.cwd(), `filereq-${id.slice(0, 8)}-submissions.csv`)\n fs.writeFileSync(filePath, data.csv, 'utf-8')\n logSuccess(`Exported to ${filePath}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-export.ts"],"names":["formsExport","id","spinner","createSpinner","data","apiGet","filePath","path","fs","logSuccess"],"mappings":"kQAMA,eAAOA,CAAAA,CAAmCC,CAAAA,CAA2B,CACnE,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,0BAA0B,CAAA,CACxDD,CAAAA,CAAQ,KAAA,EAAM,CACd,IAAME,GAAAA,CAAO,MAAMC,CAAAA,CAAwB,CAAA,cAAA,EAAiBJ,CAAE,CAAA,OAAA,CAAA,CAAW,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAChGC,EAAQ,OAAA,EAAQ,CAChB,IAAMI,CAAAA,CAAWC,CAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,EAAI,CAAG,CAAA,QAAA,EAAWN,CAAAA,CAAG,KAAA,CAAM,CAAA,CAAG,CAAC,CAAC,CAAA,gBAAA,CAAkB,CAAA,CACrFO,CAAAA,CAAG,aAAA,CAAcF,CAAAA,CAAUF,GAAAA,CAAK,GAAA,CAAK,OAAO,CAAA,CAC5CK,CAAAA,CAAW,CAAA,YAAA,EAAeH,CAAQ,CAAA,CAAE,EACtC","file":"forms-export-5SDRUFV3.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 formsExport(id: string): Promise<void> {\n const spinner = createSpinner('Exporting submissions...')\n spinner.start()\n const data = await apiGet<{ csv: string }>(`/api/v1/forms/${id}/export`, { authenticated: true })\n spinner.succeed()\n const filePath = path.join(process.cwd(), `filereq-${id.slice(0, 8)}-submissions.csv`)\n fs.writeFileSync(filePath, data.csv, 'utf-8')\n logSuccess(`Exported to ${filePath}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import o from'chalk';async function a(m$1){let i=(await c(`/api/v1/forms/${m$1}`,{authenticated:true})).form;if(f()){m(i);return}l(""),l(` ${o.bold(i.name)}`),l(o.dim(" \u2500\u2500\u2500".repeat(8))),l(` ${o.bold("ID:")} ${i.id}`),l(` ${o.bold("Folder:")} ${i.folder||o.dim("none")}`),l(` ${o.bold("Submissions:")} ${i.submission_count}`),l(` ${o.bold("Spam Protection:")} ${i.spam_protection?o.green("on"):o.dim("off")}`),l(` ${o.bold("Active:")} ${i.is_active?o.green("yes"):o.yellow("no")}`),l(` ${o.bold("Embed:")} ${o.dim(i.embed_url)}`),l("");}export{a as default};//# sourceMappingURL=forms-info-JOYOMPC3.js.map
2
+ //# sourceMappingURL=forms-info-JOYOMPC3.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-info.ts"],"names":["formsInfo","id","f","apiGet","isJsonMode","logJSON","logRaw","chalk"],"mappings":"yJAeA,eAAOA,CAAAA,CAAiCC,IAA2B,CAEjE,IAAMC,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAA6B,CAAA,cAAA,EAAiBF,GAAE,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EAC/E,IAAA,CAEf,GAAIG,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAC,CAAA,CACT,MACF,CAEAI,CAAAA,CAAO,EAAE,CAAA,CACTA,EAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAKL,CAAAA,CAAE,IAAI,CAAC,CAAA,CAAE,CAAA,CAChCI,EAAOC,CAAAA,CAAM,GAAA,CAAI,sBAAA,CAAQ,MAAA,CAAO,CAAC,CAAC,CAAC,CAAA,CACnCD,EAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,KAAK,CAAC,CAAA,cAAA,EAAiBL,CAAAA,CAAE,EAAE,EAAE,CAAA,CACpDI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,SAAS,CAAC,CAAA,UAAA,EAAaL,EAAE,MAAA,EAAUK,CAAAA,CAAM,GAAA,CAAI,MAAM,CAAC,CAAA,CAAE,CAAA,CAC7ED,CAAAA,CAAO,KAAKC,CAAAA,CAAM,IAAA,CAAK,cAAc,CAAC,CAAA,KAAA,EAAQL,CAAAA,CAAE,gBAAgB,CAAA,CAAE,EAClEI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,kBAAkB,CAAC,CAAA,CAAA,EAAIL,CAAAA,CAAE,gBAAkBK,CAAAA,CAAM,KAAA,CAAM,IAAI,CAAA,CAAIA,CAAAA,CAAM,GAAA,CAAI,KAAK,CAAC,EAAE,CAAA,CACxGD,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,SAAS,CAAC,CAAA,UAAA,EAAaL,EAAE,SAAA,CAAYK,CAAAA,CAAM,KAAA,CAAM,KAAK,CAAA,CAAIA,CAAAA,CAAM,MAAA,CAAO,IAAI,CAAC,CAAA,CAAE,CAAA,CACrGD,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,QAAQ,CAAC,cAAcA,CAAAA,CAAM,GAAA,CAAIL,CAAAA,CAAE,SAAS,CAAC,CAAA,CAAE,CAAA,CACtEI,CAAAA,CAAO,EAAE,EACX","file":"forms-info-SUST47TN.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 chalk from 'chalk'\n\ninterface FormDetail {\n id: string\n name: string\n folder: string | null\n submission_count: number\n spam_protection: boolean\n is_active: boolean\n embed_url: string\n}\n\nexport default async function formsInfo(id: string): Promise<void> {\n const data = await apiGet<{ form: FormDetail }>(`/api/v1/forms/${id}`, { authenticated: true })\n const f = data.form\n\n if (isJsonMode()) {\n logJSON(f)\n return\n }\n\n logRaw('')\n logRaw(` ${chalk.bold(f.name)}`)\n logRaw(chalk.dim(' ───'.repeat(8)))\n logRaw(` ${chalk.bold('ID:')} ${f.id}`)\n logRaw(` ${chalk.bold('Folder:')} ${f.folder || chalk.dim('none')}`)\n logRaw(` ${chalk.bold('Submissions:')} ${f.submission_count}`)\n logRaw(` ${chalk.bold('Spam Protection:')} ${f.spam_protection ? chalk.green('on') : chalk.dim('off')}`)\n logRaw(` ${chalk.bold('Active:')} ${f.is_active ? chalk.green('yes') : chalk.yellow('no')}`)\n logRaw(` ${chalk.bold('Embed:')} ${chalk.dim(f.embed_url)}`)\n logRaw('')\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-info.ts"],"names":["formsInfo","id","f","apiGet","isJsonMode","logJSON","logRaw","chalk"],"mappings":"qLAeA,eAAOA,CAAAA,CAAiCC,IAA2B,CAEjE,IAAMC,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAA6B,CAAA,cAAA,EAAiBF,GAAE,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EAC/E,IAAA,CAEf,GAAIG,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAC,CAAA,CACT,MACF,CAEAI,CAAAA,CAAO,EAAE,CAAA,CACTA,EAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAKL,CAAAA,CAAE,IAAI,CAAC,CAAA,CAAE,CAAA,CAChCI,EAAOC,CAAAA,CAAM,GAAA,CAAI,sBAAA,CAAQ,MAAA,CAAO,CAAC,CAAC,CAAC,CAAA,CACnCD,EAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,KAAK,CAAC,CAAA,cAAA,EAAiBL,CAAAA,CAAE,EAAE,EAAE,CAAA,CACpDI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,SAAS,CAAC,CAAA,UAAA,EAAaL,EAAE,MAAA,EAAUK,CAAAA,CAAM,GAAA,CAAI,MAAM,CAAC,CAAA,CAAE,CAAA,CAC7ED,CAAAA,CAAO,KAAKC,CAAAA,CAAM,IAAA,CAAK,cAAc,CAAC,CAAA,KAAA,EAAQL,CAAAA,CAAE,gBAAgB,CAAA,CAAE,EAClEI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,kBAAkB,CAAC,CAAA,CAAA,EAAIL,CAAAA,CAAE,gBAAkBK,CAAAA,CAAM,KAAA,CAAM,IAAI,CAAA,CAAIA,CAAAA,CAAM,GAAA,CAAI,KAAK,CAAC,EAAE,CAAA,CACxGD,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,SAAS,CAAC,CAAA,UAAA,EAAaL,EAAE,SAAA,CAAYK,CAAAA,CAAM,KAAA,CAAM,KAAK,CAAA,CAAIA,CAAAA,CAAM,MAAA,CAAO,IAAI,CAAC,CAAA,CAAE,CAAA,CACrGD,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,QAAQ,CAAC,cAAcA,CAAAA,CAAM,GAAA,CAAIL,CAAAA,CAAE,SAAS,CAAC,CAAA,CAAE,CAAA,CACtEI,CAAAA,CAAO,EAAE,EACX","file":"forms-info-JOYOMPC3.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 chalk from 'chalk'\n\ninterface FormDetail {\n id: string\n name: string\n folder: string | null\n submission_count: number\n spam_protection: boolean\n is_active: boolean\n embed_url: string\n}\n\nexport default async function formsInfo(id: string): Promise<void> {\n const data = await apiGet<{ form: FormDetail }>(`/api/v1/forms/${id}`, { authenticated: true })\n const f = data.form\n\n if (isJsonMode()) {\n logJSON(f)\n return\n }\n\n logRaw('')\n logRaw(` ${chalk.bold(f.name)}`)\n logRaw(chalk.dim(' ───'.repeat(8)))\n logRaw(` ${chalk.bold('ID:')} ${f.id}`)\n logRaw(` ${chalk.bold('Folder:')} ${f.folder || chalk.dim('none')}`)\n logRaw(` ${chalk.bold('Submissions:')} ${f.submission_count}`)\n logRaw(` ${chalk.bold('Spam Protection:')} ${f.spam_protection ? chalk.green('on') : chalk.dim('off')}`)\n logRaw(` ${chalk.bold('Active:')} ${f.is_active ? chalk.green('yes') : chalk.yellow('no')}`)\n logRaw(` ${chalk.bold('Embed:')} ${chalk.dim(f.embed_url)}`)\n logRaw('')\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import {a}from'./chunk-THMWE2I6.js';import {b}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import o from'chalk';async function s(){let r=((await c("/api/v1/forms",{authenticated:true})).forms||[]).map(e=>({id:o.dim(e.id.slice(0,8)),name:o.hex("#4FC3F7")(e.name),folder:o.dim(e.folder||"-"),submissions:String(e.submission_count),created:b(e.created_at),active:e.is_active?o.green("yes"):o.yellow("no")}));console.log(a(r,[{key:"id",label:"ID"},{key:"name",label:"Name"},{key:"folder",label:"Folder"},{key:"submissions",label:"Submissions"},{key:"created",label:"Created"},{key:"active",label:"Active"}]));}export{s as default};//# sourceMappingURL=forms-list-CS7J3ULK.js.map
2
+ //# sourceMappingURL=forms-list-CS7J3ULK.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-list.ts"],"names":["formsList","rows","apiGet","f","chalk","formatDate","renderTable"],"mappings":"qNAcA,eAAOA,CAAAA,EAAkD,CAEvD,IAAMC,CAAAA,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAA8B,eAAA,CAAiB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACtE,KAAA,EAAS,EAAC,EAAG,GAAA,CAAIC,CAAAA,GAAM,CACxC,EAAA,CAAIC,CAAAA,CAAM,GAAA,CAAID,CAAAA,CAAE,EAAA,CAAG,KAAA,CAAM,EAAG,CAAC,CAAC,CAAA,CAC9B,IAAA,CAAMC,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAED,CAAAA,CAAE,IAAI,CAAA,CACjC,MAAA,CAAQC,CAAAA,CAAM,IAAID,CAAAA,CAAE,MAAA,EAAU,GAAG,CAAA,CACjC,WAAA,CAAa,MAAA,CAAOA,CAAAA,CAAE,gBAAgB,CAAA,CACtC,OAAA,CAASE,CAAAA,CAAWF,CAAAA,CAAE,UAAU,CAAA,CAChC,OAAQA,CAAAA,CAAE,SAAA,CAAYC,CAAAA,CAAM,KAAA,CAAM,KAAK,CAAA,CAAIA,EAAM,MAAA,CAAO,IAAI,CAC9D,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,IAAIE,CAAAA,CAAYL,CAAAA,CAAM,CAC5B,CAAE,GAAA,CAAK,IAAA,CAAM,KAAA,CAAO,IAAK,CAAA,CACzB,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,EAC7B,CAAE,GAAA,CAAK,QAAA,CAAU,KAAA,CAAO,QAAS,CAAA,CACjC,CAAE,GAAA,CAAK,aAAA,CAAe,KAAA,CAAO,aAAc,CAAA,CAC3C,CAAE,IAAK,SAAA,CAAW,KAAA,CAAO,SAAU,CAAA,CACnC,CAAE,GAAA,CAAK,QAAA,CAAU,KAAA,CAAO,QAAS,CACnC,CAAC,CAAC,EACJ","file":"forms-list-W2UUPFFD.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatDate } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface FormInfo {\n id: string\n name: string\n folder: string\n submission_count: number\n created_at: string\n is_active: boolean\n}\n\nexport default async function formsList(): Promise<void> {\n const data = await apiGet<{ forms: FormInfo[] }>('/api/v1/forms', { authenticated: true })\n const rows = (data.forms || []).map(f => ({\n id: chalk.dim(f.id.slice(0, 8)),\n name: chalk.hex('#4FC3F7')(f.name),\n folder: chalk.dim(f.folder || '-'),\n submissions: String(f.submission_count),\n created: formatDate(f.created_at),\n active: f.is_active ? chalk.green('yes') : chalk.yellow('no'),\n }))\n console.log(renderTable(rows, [\n { key: 'id', label: 'ID' },\n { key: 'name', label: 'Name' },\n { key: 'folder', label: 'Folder' },\n { key: 'submissions', label: 'Submissions' },\n { key: 'created', label: 'Created' },\n { key: 'active', label: 'Active' },\n ]))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-list.ts"],"names":["formsList","rows","apiGet","f","chalk","formatDate","renderTable"],"mappings":"iPAcA,eAAOA,CAAAA,EAAkD,CAEvD,IAAMC,CAAAA,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAA8B,eAAA,CAAiB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACtE,KAAA,EAAS,EAAC,EAAG,GAAA,CAAIC,CAAAA,GAAM,CACxC,EAAA,CAAIC,CAAAA,CAAM,GAAA,CAAID,CAAAA,CAAE,EAAA,CAAG,KAAA,CAAM,EAAG,CAAC,CAAC,CAAA,CAC9B,IAAA,CAAMC,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAED,CAAAA,CAAE,IAAI,CAAA,CACjC,MAAA,CAAQC,CAAAA,CAAM,IAAID,CAAAA,CAAE,MAAA,EAAU,GAAG,CAAA,CACjC,WAAA,CAAa,MAAA,CAAOA,CAAAA,CAAE,gBAAgB,CAAA,CACtC,OAAA,CAASE,CAAAA,CAAWF,CAAAA,CAAE,UAAU,CAAA,CAChC,OAAQA,CAAAA,CAAE,SAAA,CAAYC,CAAAA,CAAM,KAAA,CAAM,KAAK,CAAA,CAAIA,EAAM,MAAA,CAAO,IAAI,CAC9D,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,IAAIE,CAAAA,CAAYL,CAAAA,CAAM,CAC5B,CAAE,GAAA,CAAK,IAAA,CAAM,KAAA,CAAO,IAAK,CAAA,CACzB,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,EAC7B,CAAE,GAAA,CAAK,QAAA,CAAU,KAAA,CAAO,QAAS,CAAA,CACjC,CAAE,GAAA,CAAK,aAAA,CAAe,KAAA,CAAO,aAAc,CAAA,CAC3C,CAAE,IAAK,SAAA,CAAW,KAAA,CAAO,SAAU,CAAA,CACnC,CAAE,GAAA,CAAK,QAAA,CAAU,KAAA,CAAO,QAAS,CACnC,CAAC,CAAC,EACJ","file":"forms-list-CS7J3ULK.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatDate } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface FormInfo {\n id: string\n name: string\n folder: string\n submission_count: number\n created_at: string\n is_active: boolean\n}\n\nexport default async function formsList(): Promise<void> {\n const data = await apiGet<{ forms: FormInfo[] }>('/api/v1/forms', { authenticated: true })\n const rows = (data.forms || []).map(f => ({\n id: chalk.dim(f.id.slice(0, 8)),\n name: chalk.hex('#4FC3F7')(f.name),\n folder: chalk.dim(f.folder || '-'),\n submissions: String(f.submission_count),\n created: formatDate(f.created_at),\n active: f.is_active ? chalk.green('yes') : chalk.yellow('no'),\n }))\n console.log(renderTable(rows, [\n { key: 'id', label: 'ID' },\n { key: 'name', label: 'Name' },\n { key: 'folder', label: 'Folder' },\n { key: 'submissions', label: 'Submissions' },\n { key: 'created', label: 'Created' },\n { key: 'active', label: 'Active' },\n ]))\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import {a}from'./chunk-THMWE2I6.js';import {c as c$1}from'./chunk-G4JU7IUC.js';import {f,m}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import e from'chalk';async function u(n,b){let t=await c(`/api/v1/forms/${n}/submissions`,{authenticated:true});if(f()){m(t.submissions);return}let l=(t.submissions||[]).map(i=>({id:e.dim(i.id.slice(0,8)),file:i.file_name,submitted:c$1(i.submitted_at),name:i.submitter_name||e.dim("-"),email:i.submitter_email||e.dim("-")}));console.log(a(l,[{key:"id",label:"ID"},{key:"file",label:"File"},{key:"submitted",label:"Submitted"},{key:"name",label:"Name"},{key:"email",label:"Email"}]));}export{u as default};//# sourceMappingURL=forms-submissions-KWGRYLAY.js.map
2
+ //# sourceMappingURL=forms-submissions-KWGRYLAY.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/forms/forms-submissions.ts"],"names":["formsSubmissions","id","options","data","apiGet","isJsonMode","logJSON","rows","s","chalk","formatRelative","renderTable"],"mappings":"+NAgBA,eAAOA,CAAAA,CAAwCC,CAAAA,CAAYC,EAA8C,CACvG,IAAMC,CAAAA,CAAO,MAAMC,CAAAA,CAAsC,CAAA,cAAA,EAAiBH,CAAE,CAAA,YAAA,CAAA,CAAgB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACnH,GAAII,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAAA,CAAK,WAAW,EACxB,MACF,CACA,IAAMI,CAAAA,CAAAA,CAAQJ,CAAAA,CAAK,WAAA,EAAe,EAAC,EAAG,GAAA,CAAIK,CAAAA,GAAM,CAC9C,EAAA,CAAIC,CAAAA,CAAM,IAAID,CAAAA,CAAE,EAAA,CAAG,KAAA,CAAM,CAAA,CAAG,CAAC,CAAC,EAC9B,IAAA,CAAMA,CAAAA,CAAE,SAAA,CACR,SAAA,CAAWE,CAAAA,CAAeF,CAAAA,CAAE,YAAY,CAAA,CACxC,IAAA,CAAMA,CAAAA,CAAE,cAAA,EAAkBC,CAAAA,CAAM,GAAA,CAAI,GAAG,CAAA,CACvC,KAAA,CAAOD,CAAAA,CAAE,eAAA,EAAmBC,CAAAA,CAAM,GAAA,CAAI,GAAG,CAC3C,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,GAAA,CAAIE,CAAAA,CAAYJ,EAAM,CAC5B,CAAE,GAAA,CAAK,IAAA,CAAM,KAAA,CAAO,IAAK,EACzB,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,WAAA,CAAa,KAAA,CAAO,WAAY,CAAA,CACvC,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,OAAA,CAAS,KAAA,CAAO,OAAQ,CACjC,CAAC,CAAC,EACJ","file":"forms-submissions-UTLSYPWS.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatRelative } from '../../lib/utils/format.js'\nimport { logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport chalk from 'chalk'\n\ninterface Submission {\n id: string\n submitted_at: string\n file_name: string\n file_size: number\n submitter_name: string\n submitter_email: string\n}\n\nexport default async function formsSubmissions(id: string, options?: { output?: string }): Promise<void> {\n const data = await apiGet<{ submissions: Submission[] }>(`/api/v1/forms/${id}/submissions`, { authenticated: true })\n if (isJsonMode()) {\n logJSON(data.submissions)\n return\n }\n const rows = (data.submissions || []).map(s => ({\n id: chalk.dim(s.id.slice(0, 8)),\n file: s.file_name,\n submitted: formatRelative(s.submitted_at),\n name: s.submitter_name || chalk.dim('-'),\n email: s.submitter_email || chalk.dim('-'),\n }))\n console.log(renderTable(rows, [\n { key: 'id', label: 'ID' },\n { key: 'file', label: 'File' },\n { key: 'submitted', label: 'Submitted' },\n { key: 'name', label: 'Name' },\n { key: 'email', label: 'Email' },\n ]))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/forms/forms-submissions.ts"],"names":["formsSubmissions","id","options","data","apiGet","isJsonMode","logJSON","rows","s","chalk","formatRelative","renderTable"],"mappings":"kQAgBA,eAAOA,CAAAA,CAAwCC,CAAAA,CAAYC,EAA8C,CACvG,IAAMC,CAAAA,CAAO,MAAMC,CAAAA,CAAsC,CAAA,cAAA,EAAiBH,CAAE,CAAA,YAAA,CAAA,CAAgB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACnH,GAAII,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAAA,CAAK,WAAW,EACxB,MACF,CACA,IAAMI,CAAAA,CAAAA,CAAQJ,CAAAA,CAAK,WAAA,EAAe,EAAC,EAAG,GAAA,CAAIK,CAAAA,GAAM,CAC9C,EAAA,CAAIC,CAAAA,CAAM,IAAID,CAAAA,CAAE,EAAA,CAAG,KAAA,CAAM,CAAA,CAAG,CAAC,CAAC,EAC9B,IAAA,CAAMA,CAAAA,CAAE,SAAA,CACR,SAAA,CAAWE,GAAAA,CAAeF,CAAAA,CAAE,YAAY,CAAA,CACxC,IAAA,CAAMA,CAAAA,CAAE,cAAA,EAAkBC,CAAAA,CAAM,GAAA,CAAI,GAAG,CAAA,CACvC,KAAA,CAAOD,CAAAA,CAAE,eAAA,EAAmBC,CAAAA,CAAM,GAAA,CAAI,GAAG,CAC3C,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,GAAA,CAAIE,CAAAA,CAAYJ,EAAM,CAC5B,CAAE,GAAA,CAAK,IAAA,CAAM,KAAA,CAAO,IAAK,EACzB,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,WAAA,CAAa,KAAA,CAAO,WAAY,CAAA,CACvC,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,OAAA,CAAS,KAAA,CAAO,OAAQ,CACjC,CAAC,CAAC,EACJ","file":"forms-submissions-KWGRYLAY.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatRelative } from '../../lib/utils/format.js'\nimport { logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport chalk from 'chalk'\n\ninterface Submission {\n id: string\n submitted_at: string\n file_name: string\n file_size: number\n submitter_name: string\n submitter_email: string\n}\n\nexport default async function formsSubmissions(id: string, options?: { output?: string }): Promise<void> {\n const data = await apiGet<{ submissions: Submission[] }>(`/api/v1/forms/${id}/submissions`, { authenticated: true })\n if (isJsonMode()) {\n logJSON(data.submissions)\n return\n }\n const rows = (data.submissions || []).map(s => ({\n id: chalk.dim(s.id.slice(0, 8)),\n file: s.file_name,\n submitted: formatRelative(s.submitted_at),\n name: s.submitter_name || chalk.dim('-'),\n email: s.submitter_email || chalk.dim('-'),\n }))\n console.log(renderTable(rows, [\n { key: 'id', label: 'ID' },\n { key: 'file', label: 'File' },\n { key: 'submitted', label: 'Submitted' },\n { key: 'name', label: 'Name' },\n { key: 'email', label: 'Email' },\n ]))\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import'./chunk-THMWE2I6.js';import {j,k,a as a$1,g}from'./chunk-QT7R3AXE.js';import {d,b,e}from'./chunk-W6CRHANC.js';import h from'inquirer';import i from'os';import {blake3}from'@noble/hashes/blake3';var _="https://aouqcwbdoyrccjcrhzzi.supabase.co",y="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImFvdXFjd2Jkb3lyY2NqY3JoenppIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NDI5NjAyMTEsImV4cCI6MjA1ODUzNjIxMX0.b_VHC6uP3Efw3o_yibCoZKmsCIVZgOJ4FUF1NK-nd7U";async function l(t,r){let s=await fetch(`${_}/auth/v1/token?grant_type=password`,{method:"POST",headers:{"Content-Type":"application/json",apikey:y},body:JSON.stringify({email:t,password:r})});if(!s.ok){let w=await s.text();throw new Error(w||`Authentication failed (HTTP ${s.status})`)}let e$1=await s.json(),g=b(blake3(i.hostname()+i.platform()+i.arch())),a={session_id:e$1.user.id+"-"+Date.now(),access_token:e$1.access_token,refresh_token:e$1.refresh_token,refresh_token_id:"",device_fingerprint:g,issued_at:Date.now(),expires_at:e$1.expires_at*1e3,user:{id:e$1.user.id,email:e$1.user.email,username:e$1.user.user_metadata?.username||e$1.user.email.split("@")[0]||"user",plan:"free"}};return await e(a),a}async function I(){let t=await d();if(t){j(`Already authenticated as ${t.user.email}`);let{force:e}=await h.prompt([{type:"confirm",name:"force",message:"Re-authenticate?",default:false}]);if(!e)return}let r=await h.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 l(r.email,r.password);s.succeed(),k(`Welcome to SquidCloud, ${a$1(e.user.username)}!`),g(`Authenticated as ${e.user.email} (${e.user.plan})`);}catch(e){throw s.fail(),e}}
2
+ export{I as default};//# sourceMappingURL=login-DRNKN2XZ.js.map
3
+ //# sourceMappingURL=login-DRNKN2XZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/lib/auth/ssp-handshake.ts","../src/commands/auth/login.ts"],"names":["SUPABASE_URL","ANON_KEY","performSSPHandshake","email","password","response","text","data","fingerprint","bytesToHex","blake3","os","session","saveSession","login","existing","loadSession","logInfo","force","inquirer","answers","v","spinner","createSpinner","logBrand","brand","logSuccess","err"],"mappings":"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","file":"login-DRNKN2XZ.js","sourcesContent":["import os from 'node:os'\nimport { blake3 } from '@noble/hashes/blake3'\nimport { bytesToHex, SquidSession } from '../crypto/ssp.js'\nimport { saveSession } from './session.js'\n\nconst SUPABASE_URL = 'https://aouqcwbdoyrccjcrhzzi.supabase.co'\nconst ANON_KEY = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImFvdXFjd2Jkb3lyY2NqY3JoenppIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NDI5NjAyMTEsImV4cCI6MjA1ODUzNjIxMX0.b_VHC6uP3Efw3o_yibCoZKmsCIVZgOJ4FUF1NK-nd7U'\n\ninterface SupabaseAuthResponse {\n access_token: string\n token_type: string\n expires_in: number\n expires_at: number\n refresh_token: string\n user: {\n id: string\n email: string\n user_metadata: Record<string, unknown>\n aud: string\n }\n}\n\nexport async function performSSPHandshake(email: string, password: string): Promise<SquidSession> {\n const response = await fetch(`${SUPABASE_URL}/auth/v1/token?grant_type=password`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'apikey': ANON_KEY,\n },\n body: JSON.stringify({ email, password }),\n })\n\n if (!response.ok) {\n const text = await response.text()\n throw new Error(text || `Authentication failed (HTTP ${response.status})`)\n }\n\n const data: SupabaseAuthResponse = await response.json()\n const fingerprint = bytesToHex(blake3(os.hostname() + os.platform() + os.arch()))\n\n const session: SquidSession = {\n session_id: data.user.id + '-' + Date.now(),\n access_token: data.access_token,\n refresh_token: data.refresh_token,\n refresh_token_id: '',\n device_fingerprint: fingerprint,\n issued_at: Date.now(),\n expires_at: data.expires_at * 1000,\n user: {\n id: data.user.id,\n email: data.user.email,\n username: (data.user.user_metadata?.username as string) || data.user.email.split('@')[0] || 'user',\n plan: 'free',\n },\n }\n\n await saveSession(session)\n return session\n}\n","import inquirer from 'inquirer'\nimport { performSSPHandshake } from '../../lib/auth/ssp-handshake.js'\nimport { loadSession } from '../../lib/auth/session.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logInfo, logBrand } from '../../lib/output/logger.js'\nimport { brand } from '../../lib/output/brand.js'\n\nexport default async function login(): Promise<void> {\n const existing = await loadSession()\n if (existing) {\n logInfo(`Already authenticated as ${existing.user.email}`)\n const { force } = await inquirer.prompt([{\n type: 'confirm',\n name: 'force',\n message: 'Re-authenticate?',\n default: false,\n }])\n if (!force) return\n }\n\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'email',\n message: 'Email:',\n validate: (v: string) => v.includes('@') ? true : 'Please enter a valid email',\n },\n {\n type: 'password',\n name: 'password',\n message: 'Password:',\n mask: '*',\n },\n ])\n\n const spinner = createSpinner('Authenticating with SquidCloud...')\n spinner.start()\n\n try {\n const session = await performSSPHandshake(answers.email, answers.password)\n spinner.succeed()\n logBrand(`Welcome to SquidCloud, ${brand(session.user.username)}!`)\n logSuccess(`Authenticated as ${session.user.email} (${session.user.plan})`)\n } catch (err) {\n spinner.fail()\n throw err\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import {f}from'./chunk-W6CRHANC.js';async function i(){let o=a("Revoking session...");o.start();try{await d("/api/auth/ssp/revoke",{},{authenticated:!0});}catch{}await f(),o.succeed(),g("Logged out successfully");}export{i as default};//# sourceMappingURL=logout-UF55Z67V.js.map
2
+ //# sourceMappingURL=logout-UF55Z67V.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/auth/logout.ts"],"names":["logout","spinner","createSpinner","apiPost","clearSession","logSuccess"],"mappings":"wMAKA,eAAOA,CAAAA,EAA+C,CACpD,IAAMC,GAAAA,CAAUC,EAAc,qBAAqB,CAAA,CACnDD,GAAAA,CAAQ,KAAA,EAAM,CACd,GAAI,CACF,MAAME,EAAQ,sBAAA,CAAwB,EAAC,CAAG,CAAE,aAAA,CAAe,CAAA,CAAK,CAAC,EACnE,MAAQ,CAER,CACA,MAAMC,CAAAA,GACNH,GAAAA,CAAQ,OAAA,EAAQ,CAChBI,CAAAA,CAAW,yBAAyB,EACtC","file":"logout-QERO6G6B.js","sourcesContent":["import { clearSession } from '../../lib/auth/session.js'\nimport { 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 logout(): Promise<void> {\n const spinner = createSpinner('Revoking session...')\n spinner.start()\n try {\n await apiPost('/api/auth/ssp/revoke', {}, { authenticated: true })\n } catch {\n // Proceed with local cleanup regardless\n }\n await clearSession()\n spinner.succeed()\n logSuccess('Logged out successfully')\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/auth/logout.ts"],"names":["logout","spinner","createSpinner","apiPost","clearSession","logSuccess"],"mappings":"oOAKA,eAAOA,CAAAA,EAA+C,CACpD,IAAMC,CAAAA,CAAUC,EAAc,qBAAqB,CAAA,CACnDD,CAAAA,CAAQ,KAAA,EAAM,CACd,GAAI,CACF,MAAME,EAAQ,sBAAA,CAAwB,EAAC,CAAG,CAAE,aAAA,CAAe,CAAA,CAAK,CAAC,EACnE,MAAQ,CAER,CACA,MAAMC,CAAAA,GACNH,CAAAA,CAAQ,OAAA,EAAQ,CAChBI,CAAAA,CAAW,yBAAyB,EACtC","file":"logout-UF55Z67V.js","sourcesContent":["import { clearSession } from '../../lib/auth/session.js'\nimport { 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 logout(): Promise<void> {\n const spinner = createSpinner('Revoking session...')\n spinner.start()\n try {\n await apiPost('/api/auth/ssp/revoke', {}, { authenticated: true })\n } catch {\n // Proceed with local cleanup regardless\n }\n await clearSession()\n spinner.succeed()\n logSuccess('Logged out successfully')\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a as a$1}from'./chunk-PSJQAIDB.js';import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import n from'fs';import p from'path';async function a(){let o=a$1("Exporting logs...");o.start();let i=await c("/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-O74GEMCD.js.map
2
+ //# sourceMappingURL=logs-export-O74GEMCD.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/logs/logs-export.ts"],"names":["logsExport","spinner","createSpinner","data","apiGet","filePath","path","fs","logSuccess"],"mappings":"sOAMA,eAAOA,CAAAA,EAAmD,CACxD,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,mBAAmB,EACjDD,CAAAA,CAAQ,KAAA,EAAM,CACd,IAAME,CAAAA,CAAO,MAAMC,EAA0B,qBAAA,CAAuB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC3FH,EAAQ,OAAA,EAAQ,CAChB,IAAMI,CAAAA,CAAWC,CAAAA,CAAK,IAAA,CAAK,QAAQ,GAAA,EAAI,CAAG,CAAA,gBAAA,EAAmB,IAAA,CAAK,GAAA,EAAK,QAAQ,CAAA,CAC/EC,CAAAA,CAAG,aAAA,CAAcF,CAAAA,CAAUF,CAAAA,CAAK,KAAA,CAAO,OAAO,CAAA,CAC9CK,CAAAA,CAAW,CAAA,YAAA,EAAeH,CAAQ,CAAA,CAAE,EACtC","file":"logs-export-DYOPV2LT.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 logsExport(): Promise<void> {\n const spinner = createSpinner('Exporting logs...')\n spinner.start()\n const data = await apiGet<{ jsonl: string }>('/api/v1/logs/export', { authenticated: true })\n spinner.succeed()\n const filePath = path.join(process.cwd(), `squidcloud-logs-${Date.now()}.jsonl`)\n fs.writeFileSync(filePath, data.jsonl, 'utf-8')\n logSuccess(`Exported to ${filePath}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/logs/logs-export.ts"],"names":["logsExport","spinner","createSpinner","data","apiGet","filePath","path","fs","logSuccess"],"mappings":"yQAMA,eAAOA,CAAAA,EAAmD,CACxD,IAAMC,CAAAA,CAAUC,GAAAA,CAAc,mBAAmB,EACjDD,CAAAA,CAAQ,KAAA,EAAM,CACd,IAAME,CAAAA,CAAO,MAAMC,EAA0B,qBAAA,CAAuB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC3FH,EAAQ,OAAA,EAAQ,CAChB,IAAMI,CAAAA,CAAWC,CAAAA,CAAK,IAAA,CAAK,QAAQ,GAAA,EAAI,CAAG,CAAA,gBAAA,EAAmB,IAAA,CAAK,GAAA,EAAK,QAAQ,CAAA,CAC/EC,CAAAA,CAAG,aAAA,CAAcF,CAAAA,CAAUF,CAAAA,CAAK,KAAA,CAAO,OAAO,CAAA,CAC9CK,CAAAA,CAAW,CAAA,YAAA,EAAeH,CAAQ,CAAA,CAAE,EACtC","file":"logs-export-O74GEMCD.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 logsExport(): Promise<void> {\n const spinner = createSpinner('Exporting logs...')\n spinner.start()\n const data = await apiGet<{ jsonl: string }>('/api/v1/logs/export', { authenticated: true })\n spinner.succeed()\n const filePath = path.join(process.cwd(), `squidcloud-logs-${Date.now()}.jsonl`)\n fs.writeFileSync(filePath, data.jsonl, 'utf-8')\n logSuccess(`Exported to ${filePath}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {c}from'./chunk-MU5KHPCI.js';import'./chunk-NDB6KXYI.js';import'./chunk-SVR7W7MP.js';import {a}from'./chunk-THMWE2I6.js';import {c as c$1}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-W6CRHANC.js';import r from'chalk';async function g(i,t){let a$1=new URLSearchParams({q:i});t?.from&&a$1.set("from",t.from),t?.to&&a$1.set("to",t.to);let l=((await c(`/api/v1/logs/search?${a$1}`,{authenticated:true})).logs||[]).map(e=>({ts:c$1(e.timestamp),level:e.level==="error"?r.red("\u25CF"):e.level==="warn"?r.yellow("\u25CF"):r.dim("\u25CF"),type:r.dim(e.type||"-"),message:e.message?.slice(0,80)||""}));console.log(a(l,[{key:"ts",label:"Time"},{key:"level",label:""},{key:"type",label:"Type"},{key:"message",label:"Message"}]));}export{g as default};//# sourceMappingURL=logs-search-JAGCLPVE.js.map
2
+ //# sourceMappingURL=logs-search-JAGCLPVE.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/logs/logs-search.ts"],"names":["logsSearch","query","options","params","rows","apiGet","l","formatRelative","chalk","renderTable"],"mappings":"qNAaA,eAAOA,CAAAA,CAAkCC,CAAAA,CAAeC,CAAAA,CAAyD,CAC/G,IAAMC,GAAAA,CAAS,IAAI,eAAA,CAAgB,CAAE,CAAA,CAAGF,CAAM,CAAC,CAAA,CAC3CC,CAAAA,EAAS,IAAA,EAAMC,GAAAA,CAAO,GAAA,CAAI,MAAA,CAAQD,CAAAA,CAAQ,IAAI,CAAA,CAC9CA,CAAAA,EAAS,EAAA,EAAIC,GAAAA,CAAO,GAAA,CAAI,IAAA,CAAMD,CAAAA,CAAQ,EAAE,CAAA,CAG5C,IAAME,CAAAA,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAA6B,CAAA,oBAAA,EAAuBF,GAAM,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACrF,IAAA,EAAQ,EAAC,EAAG,GAAA,CAAIG,CAAAA,GAAM,CACvC,EAAA,CAAIC,CAAAA,CAAeD,CAAAA,CAAE,SAAS,CAAA,CAC9B,KAAA,CAAOA,CAAAA,CAAE,KAAA,GAAU,OAAA,CAAUE,CAAAA,CAAM,GAAA,CAAI,QAAG,CAAA,CAAIF,CAAAA,CAAE,KAAA,GAAU,MAAA,CAASE,CAAAA,CAAM,MAAA,CAAO,QAAG,CAAA,CAAIA,CAAAA,CAAM,GAAA,CAAI,QAAG,CAAA,CACpG,IAAA,CAAMA,CAAAA,CAAM,GAAA,CAAIF,CAAAA,CAAE,IAAA,EAAQ,GAAG,CAAA,CAC7B,OAAA,CAASA,CAAAA,CAAE,OAAA,EAAS,KAAA,CAAM,CAAA,CAAG,EAAE,CAAA,EAAK,EACtC,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,GAAA,CAAIG,CAAAA,CAAYL,CAAAA,CAAM,CAC5B,CAAE,GAAA,CAAK,IAAA,CAAM,KAAA,CAAO,MAAO,CAAA,CAC3B,CAAE,GAAA,CAAK,OAAA,CAAS,KAAA,CAAO,EAAG,CAAA,CAC1B,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,SAAA,CAAW,KAAA,CAAO,SAAU,CACrC,CAAC,CAAC,EACJ","file":"logs-search-323KRPG4.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface LogEntry {\n id: string\n timestamp: string\n level: string\n type: string\n message: string\n}\n\nexport default async function logsSearch(query: string, options?: { from?: string; to?: string }): Promise<void> {\n const params = new URLSearchParams({ q: query })\n if (options?.from) params.set('from', options.from)\n if (options?.to) params.set('to', options.to)\n\n const data = await apiGet<{ logs: LogEntry[] }>(`/api/v1/logs/search?${params}`, { authenticated: true })\n const rows = (data.logs || []).map(l => ({\n ts: formatRelative(l.timestamp),\n level: l.level === 'error' ? chalk.red('●') : l.level === 'warn' ? chalk.yellow('●') : chalk.dim('●'),\n type: chalk.dim(l.type || '-'),\n message: l.message?.slice(0, 80) || '',\n }))\n console.log(renderTable(rows, [\n { key: 'ts', label: 'Time' },\n { key: 'level', label: '' },\n { key: 'type', label: 'Type' },\n { key: 'message', label: 'Message' },\n ]))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/logs/logs-search.ts"],"names":["logsSearch","query","options","params","rows","apiGet","l","formatRelative","chalk","renderTable"],"mappings":"wPAaA,eAAOA,CAAAA,CAAkCC,CAAAA,CAAeC,CAAAA,CAAyD,CAC/G,IAAMC,GAAAA,CAAS,IAAI,eAAA,CAAgB,CAAE,CAAA,CAAGF,CAAM,CAAC,CAAA,CAC3CC,CAAAA,EAAS,IAAA,EAAMC,GAAAA,CAAO,GAAA,CAAI,MAAA,CAAQD,CAAAA,CAAQ,IAAI,CAAA,CAC9CA,CAAAA,EAAS,EAAA,EAAIC,GAAAA,CAAO,GAAA,CAAI,IAAA,CAAMD,CAAAA,CAAQ,EAAE,CAAA,CAG5C,IAAME,CAAAA,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAA6B,CAAA,oBAAA,EAAuBF,GAAM,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACrF,IAAA,EAAQ,EAAC,EAAG,GAAA,CAAIG,CAAAA,GAAM,CACvC,EAAA,CAAIC,GAAAA,CAAeD,CAAAA,CAAE,SAAS,CAAA,CAC9B,KAAA,CAAOA,CAAAA,CAAE,KAAA,GAAU,OAAA,CAAUE,CAAAA,CAAM,GAAA,CAAI,QAAG,CAAA,CAAIF,CAAAA,CAAE,KAAA,GAAU,MAAA,CAASE,CAAAA,CAAM,MAAA,CAAO,QAAG,CAAA,CAAIA,CAAAA,CAAM,GAAA,CAAI,QAAG,CAAA,CACpG,IAAA,CAAMA,CAAAA,CAAM,GAAA,CAAIF,CAAAA,CAAE,IAAA,EAAQ,GAAG,CAAA,CAC7B,OAAA,CAASA,CAAAA,CAAE,OAAA,EAAS,KAAA,CAAM,CAAA,CAAG,EAAE,CAAA,EAAK,EACtC,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,GAAA,CAAIG,CAAAA,CAAYL,CAAAA,CAAM,CAC5B,CAAE,GAAA,CAAK,IAAA,CAAM,KAAA,CAAO,MAAO,CAAA,CAC3B,CAAE,GAAA,CAAK,OAAA,CAAS,KAAA,CAAO,EAAG,CAAA,CAC1B,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,SAAA,CAAW,KAAA,CAAO,SAAU,CACrC,CAAC,CAAC,EACJ","file":"logs-search-JAGCLPVE.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface LogEntry {\n id: string\n timestamp: string\n level: string\n type: string\n message: string\n}\n\nexport default async function logsSearch(query: string, options?: { from?: string; to?: string }): Promise<void> {\n const params = new URLSearchParams({ q: query })\n if (options?.from) params.set('from', options.from)\n if (options?.to) params.set('to', options.to)\n\n const data = await apiGet<{ logs: LogEntry[] }>(`/api/v1/logs/search?${params}`, { authenticated: true })\n const rows = (data.logs || []).map(l => ({\n ts: formatRelative(l.timestamp),\n level: l.level === 'error' ? chalk.red('●') : l.level === 'warn' ? chalk.yellow('●') : chalk.dim('●'),\n type: chalk.dim(l.type || '-'),\n message: l.message?.slice(0, 80) || '',\n }))\n console.log(renderTable(rows, [\n { key: 'ts', label: 'Time' },\n { key: 'level', label: '' },\n { key: 'type', label: 'Type' },\n { key: 'message', label: 'Message' },\n ]))\n}\n"]}
@@ -1,3 +1,3 @@
1
- import {a}from'./chunk-NDB6KXYI.js';import {m}from'./chunk-4NTVRCZM.js';import {WebSocket}from'ws';import e from'chalk';async function $(r){let l=await m();l||(console.error("Not authenticated"),process.exit(1));let c=a().replace(/^http/,"ws"),a$1=r?.filter?`?filter=${encodeURIComponent(r.filter)}`:"",t=new WebSocket(`${c}/api/v1/logs/tail${a$1}`,{headers:{Authorization:`Bearer ${l.access_token}`}});console.log(e.dim(`Streaming live logs...${r?.filter?` (filter: ${r.filter})`:""} (Ctrl+C to stop)`)),console.log(""),t.on("message",s=>{try{let o=JSON.parse(s.toString()),m=e.dim(new Date(o.timestamp).toLocaleTimeString()),f=o.level==="error"?e.red("error"):o.level==="warn"?e.yellow("warn"):o.level==="info"?e.hex("#4FC3F7")("info"):e.dim(o.level||"log"),g=o.type?e.dim(`[${o.type}]`):"",p=o.message||"";console.log(`${m} ${f} ${g} ${p}`);}catch{console.log(s.toString());}}),t.on("error",s=>{console.error(e.red(`WebSocket error: ${s.message}`)),process.exit(1);}),t.on("close",()=>{console.log(e.dim(`
2
- Connection closed`)),process.exit(0);}),process.on("SIGINT",()=>{t.close(),process.exit(0);});}export{$ as default};//# sourceMappingURL=logs-tail-J64TCZG5.js.map
3
- //# sourceMappingURL=logs-tail-J64TCZG5.js.map
1
+ import {a}from'./chunk-NDB6KXYI.js';import {d}from'./chunk-W6CRHANC.js';import {WebSocket}from'ws';import e from'chalk';async function $(r){let l=await d();l||(console.error("Not authenticated"),process.exit(1));let c=a().replace(/^http/,"ws"),a$1=r?.filter?`?filter=${encodeURIComponent(r.filter)}`:"",t=new WebSocket(`${c}/api/v1/logs/tail${a$1}`,{headers:{Authorization:`Bearer ${l.access_token}`}});console.log(e.dim(`Streaming live logs...${r?.filter?` (filter: ${r.filter})`:""} (Ctrl+C to stop)`)),console.log(""),t.on("message",s=>{try{let o=JSON.parse(s.toString()),m=e.dim(new Date(o.timestamp).toLocaleTimeString()),f=o.level==="error"?e.red("error"):o.level==="warn"?e.yellow("warn"):o.level==="info"?e.hex("#4FC3F7")("info"):e.dim(o.level||"log"),g=o.type?e.dim(`[${o.type}]`):"",p=o.message||"";console.log(`${m} ${f} ${g} ${p}`);}catch{console.log(s.toString());}}),t.on("error",s=>{console.error(e.red(`WebSocket error: ${s.message}`)),process.exit(1);}),t.on("close",()=>{console.log(e.dim(`
2
+ Connection closed`)),process.exit(0);}),process.on("SIGINT",()=>{t.close(),process.exit(0);});}export{$ as default};//# sourceMappingURL=logs-tail-NFHOK3RM.js.map
3
+ //# sourceMappingURL=logs-tail-NFHOK3RM.js.map