squidcloudctl 1.1.6 → 1.1.8

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 (195) hide show
  1. package/dist/{auth-revoke-UCNMKHTF.js → auth-revoke-6YX7LBWB.js} +2 -2
  2. package/dist/{auth-revoke-UCNMKHTF.js.map → auth-revoke-6YX7LBWB.js.map} +1 -1
  3. package/dist/{auth-sessions-PIBWTIT5.js → auth-sessions-2A63NMIW.js} +2 -2
  4. package/dist/{auth-sessions-PIBWTIT5.js.map → auth-sessions-2A63NMIW.js.map} +1 -1
  5. package/dist/auth-status-AOV7GJLX.js +2 -0
  6. package/dist/{auth-status-RPJVTJ4S.js.map → auth-status-AOV7GJLX.js.map} +1 -1
  7. package/dist/bin/squidcloud.js +2 -2
  8. package/dist/bin/squidcloud.js.map +1 -1
  9. package/dist/{chunk-6DKUVFZF.js → chunk-CHBVIZF5.js} +2 -2
  10. package/dist/{chunk-6DKUVFZF.js.map → chunk-CHBVIZF5.js.map} +1 -1
  11. package/dist/{chunk-2RMLR54M.js → chunk-Q3A4IBGC.js} +2 -2
  12. package/dist/chunk-Q3A4IBGC.js.map +1 -0
  13. package/dist/{chunk-Z74H5ACJ.js → chunk-ULVQ53OO.js} +3 -3
  14. package/dist/{chunk-Z74H5ACJ.js.map → chunk-ULVQ53OO.js.map} +1 -1
  15. package/dist/client-IR7OHGEQ.js +2 -0
  16. package/dist/{client-MCQSJIGH.js.map → client-IR7OHGEQ.js.map} +1 -1
  17. package/dist/{collab-activity-ESSL2DUE.js → collab-activity-YOEJEJTQ.js} +2 -2
  18. package/dist/{collab-activity-ESSL2DUE.js.map → collab-activity-YOEJEJTQ.js.map} +1 -1
  19. package/dist/{collab-invite-H6KXMBJ5.js → collab-invite-6TN62APL.js} +2 -2
  20. package/dist/{collab-invite-H6KXMBJ5.js.map → collab-invite-6TN62APL.js.map} +1 -1
  21. package/dist/{collab-leave-23J42V4P.js → collab-leave-RY2ULFWC.js} +2 -2
  22. package/dist/{collab-leave-23J42V4P.js.map → collab-leave-RY2ULFWC.js.map} +1 -1
  23. package/dist/{collab-list-6VNDTN7W.js → collab-list-M4T5NTDC.js} +2 -2
  24. package/dist/{collab-list-6VNDTN7W.js.map → collab-list-M4T5NTDC.js.map} +1 -1
  25. package/dist/collab-remove-BUD6VVD5.js +2 -0
  26. package/dist/{collab-remove-A76ARTWG.js.map → collab-remove-BUD6VVD5.js.map} +1 -1
  27. package/dist/{collab-transfer-S5MECG6Y.js → collab-transfer-R5IDVZAX.js} +2 -2
  28. package/dist/{collab-transfer-S5MECG6Y.js.map → collab-transfer-R5IDVZAX.js.map} +1 -1
  29. package/dist/{deploy-O7VVCVUR.js → deploy-QKTIRD5U.js} +3 -3
  30. package/dist/{deploy-O7VVCVUR.js.map → deploy-QKTIRD5U.js.map} +1 -1
  31. package/dist/{doctor-GAUV36VS.js → doctor-2BGIPUMM.js} +2 -2
  32. package/dist/{doctor-GAUV36VS.js.map → doctor-2BGIPUMM.js.map} +1 -1
  33. package/dist/{forms-clear-TSQ4YFPW.js → forms-clear-VTF3BEG4.js} +2 -2
  34. package/dist/{forms-clear-TSQ4YFPW.js.map → forms-clear-VTF3BEG4.js.map} +1 -1
  35. package/dist/{forms-create-IJPDTTGR.js → forms-create-EGWXMYTW.js} +2 -2
  36. package/dist/{forms-create-IJPDTTGR.js.map → forms-create-EGWXMYTW.js.map} +1 -1
  37. package/dist/{forms-delete-5Q6JVOWZ.js → forms-delete-V7SEUFPO.js} +2 -2
  38. package/dist/{forms-delete-5Q6JVOWZ.js.map → forms-delete-V7SEUFPO.js.map} +1 -1
  39. package/dist/{forms-embed-RWJ4BAPQ.js → forms-embed-2WBFYFUO.js} +3 -3
  40. package/dist/{forms-embed-RWJ4BAPQ.js.map → forms-embed-2WBFYFUO.js.map} +1 -1
  41. package/dist/{forms-export-YGKJVRUD.js → forms-export-DTHYLUF3.js} +2 -2
  42. package/dist/{forms-export-YGKJVRUD.js.map → forms-export-DTHYLUF3.js.map} +1 -1
  43. package/dist/{forms-info-NVNTIK45.js → forms-info-KAMWLIOA.js} +2 -2
  44. package/dist/{forms-info-NVNTIK45.js.map → forms-info-KAMWLIOA.js.map} +1 -1
  45. package/dist/{forms-list-UDYVBNX5.js → forms-list-5JU4JWVU.js} +2 -2
  46. package/dist/{forms-list-UDYVBNX5.js.map → forms-list-5JU4JWVU.js.map} +1 -1
  47. package/dist/{forms-submissions-LFUTUDOW.js → forms-submissions-U3YD6CC7.js} +2 -2
  48. package/dist/{forms-submissions-LFUTUDOW.js.map → forms-submissions-U3YD6CC7.js.map} +1 -1
  49. package/dist/{login-PDECY435.js → login-ANJQFQDO.js} +3 -3
  50. package/dist/{login-PDECY435.js.map → login-ANJQFQDO.js.map} +1 -1
  51. package/dist/logout-STTU7NNX.js +2 -0
  52. package/dist/{logout-D2GLIU2Y.js.map → logout-STTU7NNX.js.map} +1 -1
  53. package/dist/{logs-export-76WAIPNB.js → logs-export-62O4KT7A.js} +2 -2
  54. package/dist/{logs-export-76WAIPNB.js.map → logs-export-62O4KT7A.js.map} +1 -1
  55. package/dist/{logs-search-MA3AWP4B.js → logs-search-UP5IEJMG.js} +2 -2
  56. package/dist/{logs-search-MA3AWP4B.js.map → logs-search-UP5IEJMG.js.map} +1 -1
  57. package/dist/{logs-tail-2OMASMCD.js → logs-tail-YVFZLSC2.js} +3 -3
  58. package/dist/{logs-tail-2OMASMCD.js.map → logs-tail-YVFZLSC2.js.map} +1 -1
  59. package/dist/{monitor-LZ7R5C3D.js → monitor-37VPIJX6.js} +2 -2
  60. package/dist/{monitor-LZ7R5C3D.js.map → monitor-37VPIJX6.js.map} +1 -1
  61. package/dist/{monitor-automations-AR7MS2PL.js → monitor-automations-YKA4DME5.js} +2 -2
  62. package/dist/{monitor-automations-AR7MS2PL.js.map → monitor-automations-YKA4DME5.js.map} +1 -1
  63. package/dist/{monitor-pipelines-EASQLIQA.js → monitor-pipelines-7IS4K4ZV.js} +2 -2
  64. package/dist/{monitor-pipelines-EASQLIQA.js.map → monitor-pipelines-7IS4K4ZV.js.map} +1 -1
  65. package/dist/{monitor-sites-2QIM4XJ3.js → monitor-sites-KUC3NCAF.js} +2 -2
  66. package/dist/{monitor-sites-2QIM4XJ3.js.map → monitor-sites-KUC3NCAF.js.map} +1 -1
  67. package/dist/{monitor-storage-SMB32J37.js → monitor-storage-5UFFXOK7.js} +2 -2
  68. package/dist/{monitor-storage-SMB32J37.js.map → monitor-storage-5UFFXOK7.js.map} +1 -1
  69. package/dist/scripts-cancel-VX7VJ6J2.js +2 -0
  70. package/dist/{scripts-cancel-CQVIDKVW.js.map → scripts-cancel-VX7VJ6J2.js.map} +1 -1
  71. package/dist/{scripts-delete-TV4SX5OJ.js → scripts-delete-TZ7CJXF6.js} +2 -2
  72. package/dist/{scripts-delete-TV4SX5OJ.js.map → scripts-delete-TZ7CJXF6.js.map} +1 -1
  73. package/dist/scripts-disable-WJ7OIHFN.js +2 -0
  74. package/dist/{scripts-disable-IHPUGSTJ.js.map → scripts-disable-WJ7OIHFN.js.map} +1 -1
  75. package/dist/scripts-enable-D73CR33U.js +2 -0
  76. package/dist/{scripts-enable-ULCXRU7W.js.map → scripts-enable-D73CR33U.js.map} +1 -1
  77. package/dist/{scripts-list-XWNT7242.js → scripts-list-X4MIW736.js} +2 -2
  78. package/dist/{scripts-list-XWNT7242.js.map → scripts-list-X4MIW736.js.map} +1 -1
  79. package/dist/{scripts-logs-YBF6MTMQ.js → scripts-logs-AC5M3ZBH.js} +2 -2
  80. package/dist/{scripts-logs-YBF6MTMQ.js.map → scripts-logs-AC5M3ZBH.js.map} +1 -1
  81. package/dist/{scripts-run-FQ7EOXOH.js → scripts-run-PYGSKLVZ.js} +2 -2
  82. package/dist/{scripts-run-FQ7EOXOH.js.map → scripts-run-PYGSKLVZ.js.map} +1 -1
  83. package/dist/{scripts-status-XYGHYRZB.js → scripts-status-T4N57JWV.js} +2 -2
  84. package/dist/{scripts-status-XYGHYRZB.js.map → scripts-status-T4N57JWV.js.map} +1 -1
  85. package/dist/{scripts-validate-T7CGIPPE.js → scripts-validate-V7BWQMBO.js} +2 -2
  86. package/dist/{scripts-validate-T7CGIPPE.js.map → scripts-validate-V7BWQMBO.js.map} +1 -1
  87. package/dist/{scripts-watch-A7HEOAOE.js → scripts-watch-TZHTIL6Y.js} +2 -2
  88. package/dist/{scripts-watch-A7HEOAOE.js.map → scripts-watch-TZHTIL6Y.js.map} +1 -1
  89. package/dist/sign-cancel-5W54A3T2.js +2 -0
  90. package/dist/{sign-cancel-4YYJ2BBY.js.map → sign-cancel-5W54A3T2.js.map} +1 -1
  91. package/dist/{sign-download-VOMT2C3C.js → sign-download-Z2BRNOBQ.js} +2 -2
  92. package/dist/{sign-download-VOMT2C3C.js.map → sign-download-Z2BRNOBQ.js.map} +1 -1
  93. package/dist/{sign-list-SACY7XF3.js → sign-list-VDF5JFKH.js} +2 -2
  94. package/dist/{sign-list-SACY7XF3.js.map → sign-list-VDF5JFKH.js.map} +1 -1
  95. package/dist/{sign-request-PM7BZ56P.js → sign-request-NXOZSE5A.js} +2 -2
  96. package/dist/{sign-request-PM7BZ56P.js.map → sign-request-NXOZSE5A.js.map} +1 -1
  97. package/dist/{sign-status-LRQGO2UX.js → sign-status-E5UWZ4Y3.js} +2 -2
  98. package/dist/{sign-status-LRQGO2UX.js.map → sign-status-E5UWZ4Y3.js.map} +1 -1
  99. package/dist/{sign-verify-PQ7HBHTY.js → sign-verify-2OKPTOPN.js} +2 -2
  100. package/dist/{sign-verify-PQ7HBHTY.js.map → sign-verify-2OKPTOPN.js.map} +1 -1
  101. package/dist/{sites-analytics-J5BMYBO5.js → sites-analytics-2YAYY6GY.js} +2 -2
  102. package/dist/{sites-analytics-J5BMYBO5.js.map → sites-analytics-2YAYY6GY.js.map} +1 -1
  103. package/dist/{sites-delete-BYUJAMSX.js → sites-delete-BH7KKL54.js} +2 -2
  104. package/dist/{sites-delete-BYUJAMSX.js.map → sites-delete-BH7KKL54.js.map} +1 -1
  105. package/dist/{sites-deploys-XJQHVTET.js → sites-deploys-4HEJWQON.js} +2 -2
  106. package/dist/{sites-deploys-XJQHVTET.js.map → sites-deploys-4HEJWQON.js.map} +1 -1
  107. package/dist/{sites-info-JBM5C5FT.js → sites-info-6HE2B6TF.js} +2 -2
  108. package/dist/{sites-info-JBM5C5FT.js.map → sites-info-6HE2B6TF.js.map} +1 -1
  109. package/dist/{sites-list-4AIOO76P.js → sites-list-5GJPVLM3.js} +2 -2
  110. package/dist/{sites-list-4AIOO76P.js.map → sites-list-5GJPVLM3.js.map} +1 -1
  111. package/dist/{sites-logs-GZALCIBX.js → sites-logs-AYG43HQV.js} +3 -3
  112. package/dist/{sites-logs-GZALCIBX.js.map → sites-logs-AYG43HQV.js.map} +1 -1
  113. package/dist/sites-open-L6AHCXLV.js +3 -0
  114. package/dist/{sites-open-QJOKIMGM.js.map → sites-open-L6AHCXLV.js.map} +1 -1
  115. package/dist/sites-purge-MGNYRQC2.js +2 -0
  116. package/dist/{sites-purge-GXD673E2.js.map → sites-purge-MGNYRQC2.js.map} +1 -1
  117. package/dist/{sites-rename-BTQZRAVA.js → sites-rename-PH4X5WUY.js} +2 -2
  118. package/dist/{sites-rename-BTQZRAVA.js.map → sites-rename-PH4X5WUY.js.map} +1 -1
  119. package/dist/{sites-rollback-LZUUU4ZU.js → sites-rollback-XORREI4B.js} +2 -2
  120. package/dist/{sites-rollback-LZUUU4ZU.js.map → sites-rollback-XORREI4B.js.map} +1 -1
  121. package/dist/{sites-unpublish-IB7BTNJC.js → sites-unpublish-G22P2RRZ.js} +2 -2
  122. package/dist/{sites-unpublish-IB7BTNJC.js.map → sites-unpublish-G22P2RRZ.js.map} +1 -1
  123. package/dist/{sites-visibility-I7PIUX4B.js → sites-visibility-XPWHUOEB.js} +2 -2
  124. package/dist/{sites-visibility-I7PIUX4B.js.map → sites-visibility-XPWHUOEB.js.map} +1 -1
  125. package/dist/storage-cat-TC65RHNH.js +2 -0
  126. package/dist/{storage-cat-CFOIZEJS.js.map → storage-cat-TC65RHNH.js.map} +1 -1
  127. package/dist/storage-clean-Z2GKXPJV.js +2 -0
  128. package/dist/{storage-clean-6EN2KMOC.js.map → storage-clean-Z2GKXPJV.js.map} +1 -1
  129. package/dist/storage-cp-2EMEFPZ3.js +2 -0
  130. package/dist/{storage-cp-SCF3CFS2.js.map → storage-cp-2EMEFPZ3.js.map} +1 -1
  131. package/dist/{storage-diff-MYW5AM3C.js → storage-diff-RK2BH2QH.js} +2 -2
  132. package/dist/{storage-diff-MYW5AM3C.js.map → storage-diff-RK2BH2QH.js.map} +1 -1
  133. package/dist/storage-download-N7TOVRLD.js +3 -0
  134. package/dist/storage-download-N7TOVRLD.js.map +1 -0
  135. package/dist/{storage-info-BV7VXGTF.js → storage-info-RHCOIHFS.js} +2 -2
  136. package/dist/{storage-info-BV7VXGTF.js.map → storage-info-RHCOIHFS.js.map} +1 -1
  137. package/dist/{storage-ls-HIVJWOV6.js → storage-ls-IWYZFGA7.js} +3 -3
  138. package/dist/{storage-ls-HIVJWOV6.js.map → storage-ls-IWYZFGA7.js.map} +1 -1
  139. package/dist/storage-mkdir-5SJHSGKB.js +2 -0
  140. package/dist/{storage-mkdir-GRKUOWAJ.js.map → storage-mkdir-5SJHSGKB.js.map} +1 -1
  141. package/dist/storage-mv-W6YIOF6S.js +2 -0
  142. package/dist/{storage-mv-RYW5TXAH.js.map → storage-mv-W6YIOF6S.js.map} +1 -1
  143. package/dist/{storage-rm-PLBQC4ED.js → storage-rm-JQ4U4Y6S.js} +2 -2
  144. package/dist/{storage-rm-PLBQC4ED.js.map → storage-rm-JQ4U4Y6S.js.map} +1 -1
  145. package/dist/{storage-search-EKYRVCY2.js → storage-search-H5INCBEX.js} +2 -2
  146. package/dist/{storage-search-EKYRVCY2.js.map → storage-search-H5INCBEX.js.map} +1 -1
  147. package/dist/{storage-share-OENZM4QY.js → storage-share-SG7QWBGU.js} +2 -2
  148. package/dist/{storage-share-OENZM4QY.js.map → storage-share-SG7QWBGU.js.map} +1 -1
  149. package/dist/{storage-tag-7XTICDCD.js → storage-tag-XDJKEOTG.js} +2 -2
  150. package/dist/{storage-tag-7XTICDCD.js.map → storage-tag-XDJKEOTG.js.map} +1 -1
  151. package/dist/storage-unshare-THU4SI5I.js +2 -0
  152. package/dist/{storage-unshare-6G6YPRPN.js.map → storage-unshare-THU4SI5I.js.map} +1 -1
  153. package/dist/{storage-upload-HW4QAENK.js → storage-upload-PPP7UCAW.js} +2 -2
  154. package/dist/{storage-upload-HW4QAENK.js.map → storage-upload-PPP7UCAW.js.map} +1 -1
  155. package/dist/time-list-FLBMQONU.js +2 -0
  156. package/dist/{time-list-HUWDZZ27.js.map → time-list-FLBMQONU.js.map} +1 -1
  157. package/dist/time-lock-JAQUWZMQ.js +2 -0
  158. package/dist/{time-lock-MZ6C6DMR.js.map → time-lock-JAQUWZMQ.js.map} +1 -1
  159. package/dist/{time-proof-G6IX5SMS.js → time-proof-UXZS3V7L.js} +2 -2
  160. package/dist/{time-proof-G6IX5SMS.js.map → time-proof-UXZS3V7L.js.map} +1 -1
  161. package/dist/{time-status-UJ3XY3R5.js → time-status-HXSTJXP3.js} +2 -2
  162. package/dist/{time-status-UJ3XY3R5.js.map → time-status-HXSTJXP3.js.map} +1 -1
  163. package/dist/{time-unlock-3TUR2KVC.js → time-unlock-RJIN5EII.js} +2 -2
  164. package/dist/{time-unlock-3TUR2KVC.js.map → time-unlock-RJIN5EII.js.map} +1 -1
  165. package/dist/version-XQNUJ474.js +2 -0
  166. package/dist/version-XQNUJ474.js.map +1 -0
  167. package/dist/whoami-AIXW6EHW.js +2 -0
  168. package/dist/{whoami-C4LPZU6R.js.map → whoami-AIXW6EHW.js.map} +1 -1
  169. package/package.json +1 -1
  170. package/dist/auth-status-RPJVTJ4S.js +0 -2
  171. package/dist/chunk-2RMLR54M.js.map +0 -1
  172. package/dist/client-MCQSJIGH.js +0 -2
  173. package/dist/collab-remove-A76ARTWG.js +0 -2
  174. package/dist/logout-D2GLIU2Y.js +0 -2
  175. package/dist/scripts-cancel-CQVIDKVW.js +0 -2
  176. package/dist/scripts-disable-IHPUGSTJ.js +0 -2
  177. package/dist/scripts-enable-ULCXRU7W.js +0 -2
  178. package/dist/session-FBC5MGFA.js +0 -2
  179. package/dist/session-FBC5MGFA.js.map +0 -1
  180. package/dist/sign-cancel-4YYJ2BBY.js +0 -2
  181. package/dist/sites-open-QJOKIMGM.js +0 -3
  182. package/dist/sites-purge-GXD673E2.js +0 -2
  183. package/dist/storage-cat-CFOIZEJS.js +0 -2
  184. package/dist/storage-clean-6EN2KMOC.js +0 -2
  185. package/dist/storage-cp-SCF3CFS2.js +0 -2
  186. package/dist/storage-download-6EQJJ7SO.js +0 -3
  187. package/dist/storage-download-6EQJJ7SO.js.map +0 -1
  188. package/dist/storage-mkdir-GRKUOWAJ.js +0 -2
  189. package/dist/storage-mv-RYW5TXAH.js +0 -2
  190. package/dist/storage-unshare-6G6YPRPN.js +0 -2
  191. package/dist/time-list-HUWDZZ27.js +0 -2
  192. package/dist/time-lock-MZ6C6DMR.js +0 -2
  193. package/dist/version-LHSDYI7Q.js +0 -2
  194. package/dist/version-LHSDYI7Q.js.map +0 -1
  195. package/dist/whoami-C4LPZU6R.js +0 -2
@@ -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","bytesToHex","buf","hexToBytes","hex","MACHINE_ID_PATHS","getMachineId","p","existsSync","readFileSync","createHash","os","computeDeviceFingerprint","data","blake3","FALLBACK_DIR","path","FALLBACK_FILE","getFallbackKey","fingerprint","ikm","hkdf","sha256","storeSession","sessionJson","key","iv","randomBytes","plaintext","encrypted","gcm","fs","payload","getSession","raw","decrypted","deleteSession","loadSession","session","saveSession","clearSession","shouldRefreshToken","getTimeUntilExpiry"],"mappings":"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","file":"chunk-Q3A4IBGC.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 api_key?: string\n}\n\nexport function generateKeypair(): { pub: Uint8Array; priv: Uint8Array } {\n const priv = edUtils.randomPrivateKey()\n const pub = getPublicKey(priv)\n return { pub, priv }\n}\n\nexport function generateNonce(): Uint8Array {\n return randomBytes(32)\n}\n\nexport function hashPassword(password: string, email: string): Buffer {\n const salt = Buffer.from(email.slice(0, 32).padEnd(32, '\\x00'))\n return pbkdf2Sync(password, salt, 100000, 32, 'sha512')\n}\n\nexport function computeDeviceFingerprint(machineId: string): string {\n const data = `${machineId}:${hostname()}:${platform()}:${arch()}`\n return Buffer.from(blake3(data)).toString('hex')\n}\n\nexport function computeSignPayload(clientNonce: Uint8Array, serverNonce: Uint8Array, clientPub: Uint8Array, timestamp: number): Uint8Array {\n const payload = new Uint8Array(clientNonce.length + serverNonce.length + clientPub.length + 8)\n payload.set(clientNonce, 0)\n payload.set(serverNonce, clientNonce.length)\n payload.set(clientPub, clientNonce.length + serverNonce.length)\n const tsBuf = new Uint8Array(8)\n new DataView(tsBuf.buffer).setBigUint64(0, BigInt(timestamp), false)\n payload.set(tsBuf, clientNonce.length + serverNonce.length + clientPub.length)\n return blake3(payload)\n}\n\nexport function deriveSharedSecret(pub: Uint8Array, priv: Uint8Array): Uint8Array {\n return x25519.getSharedSecret(priv, pub)\n}\n\nexport function deriveEncryptionKey(ecdhSecret: Uint8Array, clientNonce: Uint8Array, serverNonce: Uint8Array): Uint8Array {\n const salt = new Uint8Array(clientNonce.length + serverNonce.length)\n salt.set(clientNonce, 0)\n salt.set(serverNonce, clientNonce.length)\n return hkdf(sha256, ecdhSecret, salt, HKDF_INFO, 32)\n}\n\nexport function encryptSession(session: SquidSession, key: Uint8Array): { ciphertext: Uint8Array; iv: Uint8Array; tag: Uint8Array } {\n const iv = randomBytes(12)\n const plaintext = new TextEncoder().encode(JSON.stringify(session))\n const aes = gcm(key, iv)\n const encrypted = aes.encrypt(plaintext)\n const ciphertext = encrypted.slice(0, -16)\n const tag = encrypted.slice(-16)\n return { ciphertext, iv, tag }\n}\n\nexport function decryptSession(encrypted: Uint8Array, iv: Uint8Array, tag: Uint8Array, key: Uint8Array): SquidSession {\n const combined = new Uint8Array(encrypted.length + tag.length)\n combined.set(encrypted, 0)\n combined.set(tag, encrypted.length)\n const aes = gcm(key, iv)\n const plaintext = aes.decrypt(combined)\n return JSON.parse(new TextDecoder().decode(plaintext)) as SquidSession\n}\n\nexport function verifyServerSignature(signature: Uint8Array, payload: Uint8Array, serverPub: Uint8Array): Promise<boolean> {\n return verify(signature, payload, serverPub)\n}\n\nexport function signPayload(priv: Uint8Array, payload: Uint8Array): Promise<Uint8Array> {\n return sign(payload, priv)\n}\n\nexport function computeHMAC(key: Uint8Array, data: string): string {\n return Buffer.from(hmac(sha256, key, data)).toString('hex')\n}\n\nexport function bytesToHex(buf: Uint8Array): string {\n return Buffer.from(buf).toString('hex')\n}\n\nexport function hexToBytes(hex: string): Uint8Array {\n return new Uint8Array(Buffer.from(hex, 'hex'))\n}\n","import { createHash, randomBytes } from 'node:crypto'\nimport os from 'node:os'\nimport { readFileSync, existsSync } from 'node:fs'\nimport { blake3 } from '@noble/hashes/blake3'\nimport { bytesToHex } from '../crypto/ssp.js'\n\nconst MACHINE_ID_PATHS = [\n '/etc/machine-id',\n '/var/lib/dbus/machine-id',\n '/etc/hostid',\n]\n\nfunction getMachineId(): string {\n for (const p of MACHINE_ID_PATHS) {\n try {\n if (existsSync(p)) {\n return readFileSync(p, 'utf-8').trim()\n }\n } catch {\n continue\n }\n }\n const h = createHash('sha256').update(os.hostname() + os.arch() + os.platform()).digest('hex')\n return h\n}\n\nexport function computeDeviceFingerprint(): string {\n const machineId = getMachineId()\n const components = [\n machineId,\n os.hostname(),\n os.platform(),\n os.arch(),\n os.release(),\n ]\n const data = components.join(':')\n return bytesToHex(blake3(data))\n}\n\nexport function generateDeviceId(): string {\n return randomBytes(32).toString('hex')\n}\n","import os from 'node:os'\nimport path from 'node:path'\nimport fs from 'node:fs'\nimport { randomBytes } from '@noble/hashes/utils'\nimport { sha256 } from '@noble/hashes/sha256'\nimport { hkdf } from '@noble/hashes/hkdf'\nimport { blake3 } from '@noble/hashes/blake3'\nimport { gcm } from '@noble/ciphers/aes'\nimport { bytesToHex, hexToBytes } from '../crypto/ssp.js'\nimport { computeDeviceFingerprint } from './fingerprint.js'\n\nconst FALLBACK_DIR = path.join(os.homedir(), '.squidcloud')\nconst FALLBACK_FILE = path.join(FALLBACK_DIR, '.session')\n\nfunction getFallbackKey(): Uint8Array {\n const fingerprint = computeDeviceFingerprint()\n const ikm = new TextEncoder().encode(fingerprint)\n return hkdf(sha256, ikm, new Uint8Array(32), 'squidcloud-fallback-v1', 32)\n}\n\nexport async function storeSession(sessionJson: string): Promise<void> {\n const key = getFallbackKey()\n const iv = randomBytes(12)\n const plaintext = new TextEncoder().encode(sessionJson)\n const aes = gcm(key, iv)\n const encrypted = aes.encrypt(plaintext)\n if (!fs.existsSync(FALLBACK_DIR)) {\n fs.mkdirSync(FALLBACK_DIR, { recursive: true, mode: 0o700 })\n }\n const payload = {\n iv: bytesToHex(iv),\n data: bytesToHex(encrypted),\n }\n fs.writeFileSync(FALLBACK_FILE, JSON.stringify(payload), { mode: 0o600, encoding: 'utf-8' })\n}\n\nexport async function getSession(): Promise<string | null> {\n try {\n if (!fs.existsSync(FALLBACK_FILE)) return null\n const raw = fs.readFileSync(FALLBACK_FILE, 'utf-8')\n const { iv, data } = JSON.parse(raw) as { iv: string; data: string }\n const key = getFallbackKey()\n const aes = gcm(key, hexToBytes(iv))\n const decrypted = aes.decrypt(hexToBytes(data))\n return new TextDecoder().decode(decrypted)\n } catch {\n return null\n }\n}\n\nexport async function deleteSession(): Promise<void> {\n try {\n if (fs.existsSync(FALLBACK_FILE)) {\n fs.unlinkSync(FALLBACK_FILE)\n }\n } catch {\n // ignore\n }\n}\n","import { SquidSession } from '../crypto/ssp.js'\nimport { storeSession, getSession, deleteSession } from './keychain.js'\n\nexport async function loadSession(): Promise<SquidSession | null> {\n try {\n const raw = await getSession()\n if (!raw) return null\n const session = JSON.parse(raw) as SquidSession\n if (!session.session_id || !session.access_token) {\n await deleteSession()\n return null\n }\n return session\n } catch {\n await deleteSession()\n return null\n }\n}\n\nexport async function saveSession(session: SquidSession): Promise<void> {\n await storeSession(JSON.stringify(session))\n}\n\nexport async function clearSession(): Promise<void> {\n await deleteSession()\n}\n\nexport function isSessionExpired(session: SquidSession): boolean {\n return Date.now() >= session.expires_at\n}\n\nexport function shouldRefreshToken(session: SquidSession): boolean {\n const twoMinutes = 2 * 60 * 1000\n return (session.expires_at - Date.now()) <= twoMinutes\n}\n\nexport function getTimeUntilExpiry(session: SquidSession): number {\n return session.expires_at - Date.now()\n}\n"]}
@@ -1,3 +1,3 @@
1
- import {b as b$1,a,d as d$1,c}from'./chunk-2RMLR54M.js';import s from'fs';import f from'path';import d from'os';var l="https://aouqcwbdoyrccjcrhzzi.supabase.co",y="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImFvdXFjd2Jkb3lyY2NqY3JoenppIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NDI5NjAyMTEsImV4cCI6MjA1ODUzNjIxMX0.b_VHC6uP3Efw3o_yibCoZKmsCIVZgOJ4FUF1NK-nd7U",r=f.join(d.homedir(),".squidcloud",".refresh.lock");function S(){let n=f.dirname(r);s.existsSync(n)||s.mkdirSync(n,{recursive:true,mode:448});}async function h(){S();let n=false,t=0;for(;!n&&t<50;)try{let i=s.openSync(r,"wx");s.writeSync(i,String(process.pid)),s.closeSync(i),n=!0;}catch{let i=s.statSync(r);if(Date.now()-i.mtimeMs>1e4)try{s.unlinkSync(r);}catch{}await new Promise(e=>setTimeout(e,100)),t++;}return ()=>{try{s.unlinkSync(r);}catch{}}}async function b(){let n=await h();try{let t=await b$1();if(!t)return null;let i=a();if(t.device_fingerprint!==i)return await d$1(),null;let a$1=await fetch(`${l}/auth/v1/token?grant_type=refresh_token`,{method:"POST",headers:{"Content-Type":"application/json",apikey:y},body:JSON.stringify({refresh_token:t.refresh_token})});if(!a$1.ok)return await d$1(),null;let e=await a$1.json(),c$1={...t,access_token:e.access_token,refresh_token:e.refresh_token,expires_at:e.expires_at*1e3,issued_at:Date.now(),device_fingerprint:i,user:{id:e.user.id,email:e.user.email,username:e.user.user_metadata?.username||e.user.email.split("@")[0]||"user",plan:"free"}};return await c(c$1),c$1}catch{return await d$1(),null}finally{n();}}
2
- export{b as a};//# sourceMappingURL=chunk-Z74H5ACJ.js.map
3
- //# sourceMappingURL=chunk-Z74H5ACJ.js.map
1
+ import {b as b$1,a,d as d$1,c}from'./chunk-Q3A4IBGC.js';import s from'fs';import f from'path';import d from'os';var l="https://aouqcwbdoyrccjcrhzzi.supabase.co",y="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImFvdXFjd2Jkb3lyY2NqY3JoenppIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NDI5NjAyMTEsImV4cCI6MjA1ODUzNjIxMX0.b_VHC6uP3Efw3o_yibCoZKmsCIVZgOJ4FUF1NK-nd7U",r=f.join(d.homedir(),".squidcloud",".refresh.lock");function S(){let n=f.dirname(r);s.existsSync(n)||s.mkdirSync(n,{recursive:true,mode:448});}async function h(){S();let n=false,t=0;for(;!n&&t<50;)try{let i=s.openSync(r,"wx");s.writeSync(i,String(process.pid)),s.closeSync(i),n=!0;}catch{let i=s.statSync(r);if(Date.now()-i.mtimeMs>1e4)try{s.unlinkSync(r);}catch{}await new Promise(e=>setTimeout(e,100)),t++;}return ()=>{try{s.unlinkSync(r);}catch{}}}async function b(){let n=await h();try{let t=await b$1();if(!t)return null;let i=a();if(t.device_fingerprint!==i)return await d$1(),null;let a$1=await fetch(`${l}/auth/v1/token?grant_type=refresh_token`,{method:"POST",headers:{"Content-Type":"application/json",apikey:y},body:JSON.stringify({refresh_token:t.refresh_token})});if(!a$1.ok)return await d$1(),null;let e=await a$1.json(),c$1={...t,access_token:e.access_token,refresh_token:e.refresh_token,expires_at:e.expires_at*1e3,issued_at:Date.now(),device_fingerprint:i,user:{id:e.user.id,email:e.user.email,username:e.user.user_metadata?.username||e.user.email.split("@")[0]||"user",plan:"free"}};return await c(c$1),c$1}catch{return await d$1(),null}finally{n();}}
2
+ export{b as a};//# sourceMappingURL=chunk-ULVQ53OO.js.map
3
+ //# sourceMappingURL=chunk-ULVQ53OO.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/lib/auth/refresh.ts"],"names":["SUPABASE_URL","ANON_KEY","LOCK_FILE","path","os","ensureLockDir","dir","fs","acquireLock","acquired","attempts","fd","stat","r","refreshAccessToken","release","session","loadSession","fingerprint","computeDeviceFingerprint","clearSession","response","data","newSession","saveSession"],"mappings":"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","file":"chunk-Z74H5ACJ.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\nimport os from 'node:os'\nimport { SquidSession } from '../crypto/ssp.js'\nimport { computeDeviceFingerprint } from './fingerprint.js'\nimport { loadSession, saveSession, clearSession } from './session.js'\n\nconst SUPABASE_URL = 'https://aouqcwbdoyrccjcrhzzi.supabase.co'\nconst ANON_KEY = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImFvdXFjd2Jkb3lyY2NqY3JoenppIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NDI5NjAyMTEsImV4cCI6MjA1ODUzNjIxMX0.b_VHC6uP3Efw3o_yibCoZKmsCIVZgOJ4FUF1NK-nd7U'\n\nconst LOCK_FILE = path.join(os.homedir(), '.squidcloud', '.refresh.lock')\n\nfunction ensureLockDir(): void {\n const dir = path.dirname(LOCK_FILE)\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true, mode: 0o700 })\n }\n}\n\nasync function acquireLock(): Promise<() => void> {\n ensureLockDir()\n let acquired = false\n let attempts = 0\n while (!acquired && attempts < 50) {\n try {\n const fd = fs.openSync(LOCK_FILE, 'wx')\n fs.writeSync(fd, String(process.pid))\n fs.closeSync(fd)\n acquired = true\n } catch {\n const stat = fs.statSync(LOCK_FILE)\n const age = Date.now() - stat.mtimeMs\n if (age > 10000) {\n try { fs.unlinkSync(LOCK_FILE) } catch {}\n }\n await new Promise(r => setTimeout(r, 100))\n attempts++\n }\n }\n return () => {\n try { fs.unlinkSync(LOCK_FILE) } catch {}\n }\n}\n\ninterface SupabaseRefreshResponse {\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 }\n}\n\nexport async function refreshAccessToken(): Promise<SquidSession | null> {\n const release = await acquireLock()\n try {\n const session = await loadSession()\n if (!session) return null\n\n const fingerprint = computeDeviceFingerprint()\n if (session.device_fingerprint !== fingerprint) {\n await clearSession()\n return null\n }\n\n const response = await fetch(`${SUPABASE_URL}/auth/v1/token?grant_type=refresh_token`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'apikey': ANON_KEY,\n },\n body: JSON.stringify({ refresh_token: session.refresh_token }),\n })\n\n if (!response.ok) {\n await clearSession()\n return null\n }\n\n const data: SupabaseRefreshResponse = await response.json()\n\n const newSession: SquidSession = {\n ...session,\n access_token: data.access_token,\n refresh_token: data.refresh_token,\n expires_at: data.expires_at * 1000,\n issued_at: Date.now(),\n device_fingerprint: fingerprint,\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 await saveSession(newSession)\n return newSession\n } catch {\n await clearSession()\n return null\n } finally {\n release()\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/lib/auth/refresh.ts"],"names":["SUPABASE_URL","ANON_KEY","LOCK_FILE","path","os","ensureLockDir","dir","fs","acquireLock","acquired","attempts","fd","stat","r","refreshAccessToken","release","session","loadSession","fingerprint","computeDeviceFingerprint","clearSession","response","data","newSession","saveSession"],"mappings":"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","file":"chunk-ULVQ53OO.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\nimport os from 'node:os'\nimport { SquidSession } from '../crypto/ssp.js'\nimport { computeDeviceFingerprint } from './fingerprint.js'\nimport { loadSession, saveSession, clearSession } from './session.js'\n\nconst SUPABASE_URL = 'https://aouqcwbdoyrccjcrhzzi.supabase.co'\nconst ANON_KEY = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImFvdXFjd2Jkb3lyY2NqY3JoenppIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NDI5NjAyMTEsImV4cCI6MjA1ODUzNjIxMX0.b_VHC6uP3Efw3o_yibCoZKmsCIVZgOJ4FUF1NK-nd7U'\n\nconst LOCK_FILE = path.join(os.homedir(), '.squidcloud', '.refresh.lock')\n\nfunction ensureLockDir(): void {\n const dir = path.dirname(LOCK_FILE)\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true, mode: 0o700 })\n }\n}\n\nasync function acquireLock(): Promise<() => void> {\n ensureLockDir()\n let acquired = false\n let attempts = 0\n while (!acquired && attempts < 50) {\n try {\n const fd = fs.openSync(LOCK_FILE, 'wx')\n fs.writeSync(fd, String(process.pid))\n fs.closeSync(fd)\n acquired = true\n } catch {\n const stat = fs.statSync(LOCK_FILE)\n const age = Date.now() - stat.mtimeMs\n if (age > 10000) {\n try { fs.unlinkSync(LOCK_FILE) } catch {}\n }\n await new Promise(r => setTimeout(r, 100))\n attempts++\n }\n }\n return () => {\n try { fs.unlinkSync(LOCK_FILE) } catch {}\n }\n}\n\ninterface SupabaseRefreshResponse {\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 }\n}\n\nexport async function refreshAccessToken(): Promise<SquidSession | null> {\n const release = await acquireLock()\n try {\n const session = await loadSession()\n if (!session) return null\n\n const fingerprint = computeDeviceFingerprint()\n if (session.device_fingerprint !== fingerprint) {\n await clearSession()\n return null\n }\n\n const response = await fetch(`${SUPABASE_URL}/auth/v1/token?grant_type=refresh_token`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'apikey': ANON_KEY,\n },\n body: JSON.stringify({ refresh_token: session.refresh_token }),\n })\n\n if (!response.ok) {\n await clearSession()\n return null\n }\n\n const data: SupabaseRefreshResponse = await response.json()\n\n const newSession: SquidSession = {\n ...session,\n access_token: data.access_token,\n refresh_token: data.refresh_token,\n expires_at: data.expires_at * 1000,\n issued_at: Date.now(),\n device_fingerprint: fingerprint,\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 await saveSession(newSession)\n return newSession\n } catch {\n await clearSession()\n return null\n } finally {\n release()\n }\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-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-Q3A4IBGC.js';//# sourceMappingURL=client-IR7OHGEQ.js.map
2
+ //# sourceMappingURL=client-IR7OHGEQ.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"client-MCQSJIGH.js"}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"client-IR7OHGEQ.js"}
@@ -1,2 +1,2 @@
1
- import {a}from'./chunk-NDB6KXYI.js';import {b}from'./chunk-2RMLR54M.js';import {WebSocket}from'ws';import e from'chalk';async function f(r){let i=await b();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-ESSL2DUE.js.map
2
- //# sourceMappingURL=collab-activity-ESSL2DUE.js.map
1
+ import {a}from'./chunk-NDB6KXYI.js';import {b}from'./chunk-Q3A4IBGC.js';import {WebSocket}from'ws';import e from'chalk';async function f(r){let i=await b();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-YOEJEJTQ.js.map
2
+ //# sourceMappingURL=collab-activity-YOEJEJTQ.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-ESSL2DUE.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-YOEJEJTQ.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,2 +1,2 @@
1
- import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-H6KXMBJ5.js.map
2
- //# sourceMappingURL=collab-invite-H6KXMBJ5.js.map
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-6TN62APL.js.map
2
+ //# sourceMappingURL=collab-invite-6TN62APL.js.map
@@ -1 +1 @@
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-H6KXMBJ5.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-6TN62APL.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,2 +1,2 @@
1
- import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-23J42V4P.js.map
2
- //# sourceMappingURL=collab-leave-23J42V4P.js.map
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-RY2ULFWC.js.map
2
+ //# sourceMappingURL=collab-leave-RY2ULFWC.js.map
@@ -1 +1 @@
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-23J42V4P.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-RY2ULFWC.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,2 +1,2 @@
1
- import {c}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import {a}from'./chunk-THMWE2I6.js';import {c as c$1}from'./chunk-FZKCZRJZ.js';import'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-6VNDTN7W.js.map
2
- //# sourceMappingURL=collab-list-6VNDTN7W.js.map
1
+ import {c as c$1}from'./chunk-FZKCZRJZ.js';import {c}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import {a}from'./chunk-THMWE2I6.js';import'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-M4T5NTDC.js.map
2
+ //# sourceMappingURL=collab-list-M4T5NTDC.js.map
@@ -1 +1 @@
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-6VNDTN7W.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-M4T5NTDC.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-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-BUD6VVD5.js.map
2
+ //# sourceMappingURL=collab-remove-BUD6VVD5.js.map
@@ -1 +1 @@
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-A76ARTWG.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-BUD6VVD5.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,2 +1,2 @@
1
- import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-S5MECG6Y.js.map
2
- //# sourceMappingURL=collab-transfer-S5MECG6Y.js.map
1
+ import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-R5IDVZAX.js.map
2
+ //# sourceMappingURL=collab-transfer-R5IDVZAX.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":"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-S5MECG6Y.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-R5IDVZAX.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,3 +1,3 @@
1
- import {a as a$1}from'./chunk-MKRWNV2T.js';import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {h as h$1,i,f,m,g,c,b}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-O7VVCVUR.js.map
3
- //# sourceMappingURL=deploy-O7VVCVUR.js.map
1
+ import {a as a$1}from'./chunk-MKRWNV2T.js';import {a}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {h as h$1,i,f,m,g,c,b}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-QKTIRD5U.js.map
3
+ //# sourceMappingURL=deploy-QKTIRD5U.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-O7VVCVUR.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-QKTIRD5U.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,2 +1,2 @@
1
- import {c}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import {b,a}from'./chunk-2RMLR54M.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 b();if(o){let a$1=o.device_fingerprint===a();t.push({name:"Auth Session",status:a$1?"pass":"warn",message:a$1?`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("/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:a().slice(0,16)+"..."});try{let a=await c("/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-GAUV36VS.js.map
2
- //# sourceMappingURL=doctor-GAUV36VS.js.map
1
+ import {c}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import {b,a}from'./chunk-Q3A4IBGC.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 b();if(o){let a$1=o.device_fingerprint===a();t.push({name:"Auth Session",status:a$1?"pass":"warn",message:a$1?`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("/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:a().slice(0,16)+"..."});try{let a=await c("/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-2BGIPUMM.js.map
2
+ //# sourceMappingURL=doctor-2BGIPUMM.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-GAUV36VS.js","sourcesContent":["import 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-2BGIPUMM.js","sourcesContent":["import 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,2 +1,2 @@
1
- import {a}from'./chunk-PSJQAIDB.js';import {f}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-TSQ4YFPW.js.map
2
- //# sourceMappingURL=forms-clear-TSQ4YFPW.js.map
1
+ import {a}from'./chunk-PSJQAIDB.js';import {f}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-VTF3BEG4.js.map
2
+ //# sourceMappingURL=forms-clear-VTF3BEG4.js.map
@@ -1 +1 @@
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-TSQ4YFPW.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-VTF3BEG4.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,2 +1,2 @@
1
- import {a as a$1}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {f,m,g}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-IJPDTTGR.js.map
2
- //# sourceMappingURL=forms-create-IJPDTTGR.js.map
1
+ import {a as a$1}from'./chunk-PSJQAIDB.js';import {d}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {f,m,g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-EGWXMYTW.js.map
2
+ //# sourceMappingURL=forms-create-EGWXMYTW.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":"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-IJPDTTGR.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-EGWXMYTW.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,2 +1,2 @@
1
- import {a}from'./chunk-PSJQAIDB.js';import {f}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.js';import s from'inquirer';async function p(t){let e=(await(await import('./client-MCQSJIGH.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-5Q6JVOWZ.js.map
2
- //# sourceMappingURL=forms-delete-5Q6JVOWZ.js.map
1
+ import {a}from'./chunk-PSJQAIDB.js';import {f}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.js';import s from'inquirer';async function p(t){let e=(await(await import('./client-IR7OHGEQ.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-V7SEUFPO.js.map
2
+ //# sourceMappingURL=forms-delete-V7SEUFPO.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":"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-5Q6JVOWZ.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-V7SEUFPO.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,3 +1,3 @@
1
- import {c}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-2RMLR54M.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-RWJ4BAPQ.js.map
3
- //# sourceMappingURL=forms-embed-RWJ4BAPQ.js.map
1
+ import {c}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-Q3A4IBGC.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-2WBFYFUO.js.map
3
+ //# sourceMappingURL=forms-embed-2WBFYFUO.js.map
@@ -1 +1 @@
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-RWJ4BAPQ.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-2WBFYFUO.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,2 +1,2 @@
1
- import {a}from'./chunk-PSJQAIDB.js';import {c}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-YGKJVRUD.js.map
2
- //# sourceMappingURL=forms-export-YGKJVRUD.js.map
1
+ import {a}from'./chunk-PSJQAIDB.js';import {c}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-DTHYLUF3.js.map
2
+ //# sourceMappingURL=forms-export-DTHYLUF3.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":"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-YGKJVRUD.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-DTHYLUF3.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,2 +1,2 @@
1
- import {c}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-NVNTIK45.js.map
2
- //# sourceMappingURL=forms-info-NVNTIK45.js.map
1
+ import {c}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-KAMWLIOA.js.map
2
+ //# sourceMappingURL=forms-info-KAMWLIOA.js.map
@@ -1 +1 @@
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-NVNTIK45.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-KAMWLIOA.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,2 +1,2 @@
1
- import {c}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import {a}from'./chunk-THMWE2I6.js';import {b}from'./chunk-FZKCZRJZ.js';import'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-UDYVBNX5.js.map
2
- //# sourceMappingURL=forms-list-UDYVBNX5.js.map
1
+ import {b}from'./chunk-FZKCZRJZ.js';import {c}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import {a}from'./chunk-THMWE2I6.js';import'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-5JU4JWVU.js.map
2
+ //# sourceMappingURL=forms-list-5JU4JWVU.js.map
@@ -1 +1 @@
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-UDYVBNX5.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-5JU4JWVU.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,2 +1,2 @@
1
- import {c}from'./chunk-6DKUVFZF.js';import'./chunk-NDB6KXYI.js';import'./chunk-Z74H5ACJ.js';import {a}from'./chunk-THMWE2I6.js';import {c as c$1}from'./chunk-FZKCZRJZ.js';import {f,m}from'./chunk-QT7R3AXE.js';import'./chunk-2RMLR54M.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-LFUTUDOW.js.map
2
- //# sourceMappingURL=forms-submissions-LFUTUDOW.js.map
1
+ import {c as c$1}from'./chunk-FZKCZRJZ.js';import {c}from'./chunk-CHBVIZF5.js';import'./chunk-NDB6KXYI.js';import'./chunk-ULVQ53OO.js';import {a}from'./chunk-THMWE2I6.js';import {f,m}from'./chunk-QT7R3AXE.js';import'./chunk-Q3A4IBGC.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-U3YD6CC7.js.map
2
+ //# sourceMappingURL=forms-submissions-U3YD6CC7.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":"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-LFUTUDOW.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-U3YD6CC7.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"]}