@protontech/drive-sdk 0.0.10

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 (594) hide show
  1. package/README.md +17 -0
  2. package/dist/cache/index.d.ts +2 -0
  3. package/dist/cache/index.js +6 -0
  4. package/dist/cache/index.js.map +1 -0
  5. package/dist/cache/interface.d.ts +105 -0
  6. package/dist/cache/interface.js +3 -0
  7. package/dist/cache/interface.js.map +1 -0
  8. package/dist/cache/memoryCache.d.ts +18 -0
  9. package/dist/cache/memoryCache.js +78 -0
  10. package/dist/cache/memoryCache.js.map +1 -0
  11. package/dist/cache/memoryCache.test.d.ts +1 -0
  12. package/dist/cache/memoryCache.test.js +121 -0
  13. package/dist/cache/memoryCache.test.js.map +1 -0
  14. package/dist/config.d.ts +2 -0
  15. package/dist/config.js +11 -0
  16. package/dist/config.js.map +1 -0
  17. package/dist/crypto/driveCrypto.d.ts +209 -0
  18. package/dist/crypto/driveCrypto.js +364 -0
  19. package/dist/crypto/driveCrypto.js.map +1 -0
  20. package/dist/crypto/driveCrypto.test.d.ts +1 -0
  21. package/dist/crypto/driveCrypto.test.js +42 -0
  22. package/dist/crypto/driveCrypto.test.js.map +1 -0
  23. package/dist/crypto/hmac.d.ts +22 -0
  24. package/dist/crypto/hmac.js +44 -0
  25. package/dist/crypto/hmac.js.map +1 -0
  26. package/dist/crypto/index.d.ts +6 -0
  27. package/dist/crypto/index.js +13 -0
  28. package/dist/crypto/index.js.map +1 -0
  29. package/dist/crypto/interface.d.ts +125 -0
  30. package/dist/crypto/interface.js +10 -0
  31. package/dist/crypto/interface.js.map +1 -0
  32. package/dist/crypto/openPGPCrypto.d.ts +145 -0
  33. package/dist/crypto/openPGPCrypto.js +250 -0
  34. package/dist/crypto/openPGPCrypto.js.map +1 -0
  35. package/dist/crypto/utils.d.ts +2 -0
  36. package/dist/crypto/utils.js +35 -0
  37. package/dist/crypto/utils.js.map +1 -0
  38. package/dist/errors.d.ts +138 -0
  39. package/dist/errors.js +163 -0
  40. package/dist/errors.js.map +1 -0
  41. package/dist/index.d.ts +24 -0
  42. package/dist/index.js +48 -0
  43. package/dist/index.js.map +1 -0
  44. package/dist/interface/account.d.ts +36 -0
  45. package/dist/interface/account.js +3 -0
  46. package/dist/interface/account.js.map +1 -0
  47. package/dist/interface/author.d.ts +26 -0
  48. package/dist/interface/author.js +3 -0
  49. package/dist/interface/author.js.map +1 -0
  50. package/dist/interface/devices.d.ts +18 -0
  51. package/dist/interface/devices.js +10 -0
  52. package/dist/interface/devices.js.map +1 -0
  53. package/dist/interface/download.d.ts +29 -0
  54. package/dist/interface/download.js +3 -0
  55. package/dist/interface/download.js.map +1 -0
  56. package/dist/interface/events.d.ts +26 -0
  57. package/dist/interface/events.js +11 -0
  58. package/dist/interface/events.js.map +1 -0
  59. package/dist/interface/httpClient.d.ts +38 -0
  60. package/dist/interface/httpClient.js +3 -0
  61. package/dist/interface/httpClient.js.map +1 -0
  62. package/dist/interface/index.d.ts +43 -0
  63. package/dist/interface/index.js +22 -0
  64. package/dist/interface/index.js.map +1 -0
  65. package/dist/interface/nodes.d.ts +161 -0
  66. package/dist/interface/nodes.js +21 -0
  67. package/dist/interface/nodes.js.map +1 -0
  68. package/dist/interface/result.d.ts +9 -0
  69. package/dist/interface/result.js +11 -0
  70. package/dist/interface/result.js.map +1 -0
  71. package/dist/interface/sharing.d.ts +73 -0
  72. package/dist/interface/sharing.js +9 -0
  73. package/dist/interface/sharing.js.map +1 -0
  74. package/dist/interface/telemetry.d.ts +61 -0
  75. package/dist/interface/telemetry.js +18 -0
  76. package/dist/interface/telemetry.js.map +1 -0
  77. package/dist/interface/thumbnail.d.ts +17 -0
  78. package/dist/interface/thumbnail.js +9 -0
  79. package/dist/interface/thumbnail.js.map +1 -0
  80. package/dist/interface/upload.d.ts +16 -0
  81. package/dist/interface/upload.js +3 -0
  82. package/dist/interface/upload.js.map +1 -0
  83. package/dist/internal/apiService/apiService.d.ts +51 -0
  84. package/dist/internal/apiService/apiService.js +305 -0
  85. package/dist/internal/apiService/apiService.js.map +1 -0
  86. package/dist/internal/apiService/apiService.test.d.ts +1 -0
  87. package/dist/internal/apiService/apiService.test.js +237 -0
  88. package/dist/internal/apiService/apiService.test.js.map +1 -0
  89. package/dist/internal/apiService/coreTypes.d.ts +24438 -0
  90. package/dist/internal/apiService/coreTypes.js +7 -0
  91. package/dist/internal/apiService/coreTypes.js.map +1 -0
  92. package/dist/internal/apiService/driveTypes.d.ts +11840 -0
  93. package/dist/internal/apiService/driveTypes.js +7 -0
  94. package/dist/internal/apiService/driveTypes.js.map +1 -0
  95. package/dist/internal/apiService/errorCodes.d.ts +30 -0
  96. package/dist/internal/apiService/errorCodes.js +11 -0
  97. package/dist/internal/apiService/errorCodes.js.map +1 -0
  98. package/dist/internal/apiService/errors.d.ts +19 -0
  99. package/dist/internal/apiService/errors.js +76 -0
  100. package/dist/internal/apiService/errors.js.map +1 -0
  101. package/dist/internal/apiService/errors.test.d.ts +1 -0
  102. package/dist/internal/apiService/errors.test.js +69 -0
  103. package/dist/internal/apiService/errors.test.js.map +1 -0
  104. package/dist/internal/apiService/index.d.ts +7 -0
  105. package/dist/internal/apiService/index.js +30 -0
  106. package/dist/internal/apiService/index.js.map +1 -0
  107. package/dist/internal/apiService/observerStream.d.ts +3 -0
  108. package/dist/internal/apiService/observerStream.js +15 -0
  109. package/dist/internal/apiService/observerStream.js.map +1 -0
  110. package/dist/internal/apiService/transformers.d.ts +4 -0
  111. package/dist/internal/apiService/transformers.js +48 -0
  112. package/dist/internal/apiService/transformers.js.map +1 -0
  113. package/dist/internal/batchLoading.d.ts +34 -0
  114. package/dist/internal/batchLoading.js +68 -0
  115. package/dist/internal/batchLoading.js.map +1 -0
  116. package/dist/internal/batchLoading.test.d.ts +1 -0
  117. package/dist/internal/batchLoading.test.js +50 -0
  118. package/dist/internal/batchLoading.test.js.map +1 -0
  119. package/dist/internal/devices/apiService.d.ts +38 -0
  120. package/dist/internal/devices/apiService.js +105 -0
  121. package/dist/internal/devices/apiService.js.map +1 -0
  122. package/dist/internal/devices/cryptoService.d.ts +30 -0
  123. package/dist/internal/devices/cryptoService.js +47 -0
  124. package/dist/internal/devices/cryptoService.js.map +1 -0
  125. package/dist/internal/devices/index.d.ts +15 -0
  126. package/dist/internal/devices/index.js +22 -0
  127. package/dist/internal/devices/index.js.map +1 -0
  128. package/dist/internal/devices/interface.d.ts +31 -0
  129. package/dist/internal/devices/interface.js +3 -0
  130. package/dist/internal/devices/interface.js.map +1 -0
  131. package/dist/internal/devices/manager.d.ts +18 -0
  132. package/dist/internal/devices/manager.js +103 -0
  133. package/dist/internal/devices/manager.js.map +1 -0
  134. package/dist/internal/devices/manager.test.d.ts +1 -0
  135. package/dist/internal/devices/manager.test.js +100 -0
  136. package/dist/internal/devices/manager.test.js.map +1 -0
  137. package/dist/internal/download/apiService.d.ts +27 -0
  138. package/dist/internal/download/apiService.js +110 -0
  139. package/dist/internal/download/apiService.js.map +1 -0
  140. package/dist/internal/download/controller.d.ts +8 -0
  141. package/dist/internal/download/controller.js +22 -0
  142. package/dist/internal/download/controller.js.map +1 -0
  143. package/dist/internal/download/cryptoService.d.ts +17 -0
  144. package/dist/internal/download/cryptoService.js +82 -0
  145. package/dist/internal/download/cryptoService.js.map +1 -0
  146. package/dist/internal/download/fileDownloader.d.ts +33 -0
  147. package/dist/internal/download/fileDownloader.js +226 -0
  148. package/dist/internal/download/fileDownloader.js.map +1 -0
  149. package/dist/internal/download/fileDownloader.test.d.ts +1 -0
  150. package/dist/internal/download/fileDownloader.test.js +324 -0
  151. package/dist/internal/download/fileDownloader.test.js.map +1 -0
  152. package/dist/internal/download/index.d.ts +10 -0
  153. package/dist/internal/download/index.js +82 -0
  154. package/dist/internal/download/index.js.map +1 -0
  155. package/dist/internal/download/interface.d.ts +35 -0
  156. package/dist/internal/download/interface.js +3 -0
  157. package/dist/internal/download/interface.js.map +1 -0
  158. package/dist/internal/download/queue.d.ts +5 -0
  159. package/dist/internal/download/queue.js +31 -0
  160. package/dist/internal/download/queue.js.map +1 -0
  161. package/dist/internal/download/telemetry.d.ts +14 -0
  162. package/dist/internal/download/telemetry.js +106 -0
  163. package/dist/internal/download/telemetry.js.map +1 -0
  164. package/dist/internal/download/telemetry.test.d.ts +1 -0
  165. package/dist/internal/download/telemetry.test.js +111 -0
  166. package/dist/internal/download/telemetry.test.js.map +1 -0
  167. package/dist/internal/download/thumbnailDownloader.d.ts +19 -0
  168. package/dist/internal/download/thumbnailDownloader.js +198 -0
  169. package/dist/internal/download/thumbnailDownloader.js.map +1 -0
  170. package/dist/internal/download/thumbnailDownloader.test.d.ts +1 -0
  171. package/dist/internal/download/thumbnailDownloader.test.js +179 -0
  172. package/dist/internal/download/thumbnailDownloader.test.js.map +1 -0
  173. package/dist/internal/errors.d.ts +6 -0
  174. package/dist/internal/errors.js +28 -0
  175. package/dist/internal/errors.js.map +1 -0
  176. package/dist/internal/errors.test.d.ts +1 -0
  177. package/dist/internal/errors.test.js +22 -0
  178. package/dist/internal/errors.test.js.map +1 -0
  179. package/dist/internal/events/apiService.d.ts +18 -0
  180. package/dist/internal/events/apiService.js +81 -0
  181. package/dist/internal/events/apiService.js.map +1 -0
  182. package/dist/internal/events/cache.d.ts +28 -0
  183. package/dist/internal/events/cache.js +67 -0
  184. package/dist/internal/events/cache.js.map +1 -0
  185. package/dist/internal/events/cache.test.d.ts +1 -0
  186. package/dist/internal/events/cache.test.js +43 -0
  187. package/dist/internal/events/cache.test.js.map +1 -0
  188. package/dist/internal/events/coreEventManager.d.ts +25 -0
  189. package/dist/internal/events/coreEventManager.js +63 -0
  190. package/dist/internal/events/coreEventManager.js.map +1 -0
  191. package/dist/internal/events/eventManager.d.ts +62 -0
  192. package/dist/internal/events/eventManager.js +159 -0
  193. package/dist/internal/events/eventManager.js.map +1 -0
  194. package/dist/internal/events/eventManager.test.d.ts +1 -0
  195. package/dist/internal/events/eventManager.test.js +120 -0
  196. package/dist/internal/events/eventManager.test.js.map +1 -0
  197. package/dist/internal/events/index.d.ts +50 -0
  198. package/dist/internal/events/index.js +117 -0
  199. package/dist/internal/events/index.js.map +1 -0
  200. package/dist/internal/events/interface.d.ts +47 -0
  201. package/dist/internal/events/interface.js +12 -0
  202. package/dist/internal/events/interface.js.map +1 -0
  203. package/dist/internal/events/volumeEventManager.d.ts +27 -0
  204. package/dist/internal/events/volumeEventManager.js +69 -0
  205. package/dist/internal/events/volumeEventManager.js.map +1 -0
  206. package/dist/internal/nodes/apiService.d.ts +54 -0
  207. package/dist/internal/nodes/apiService.js +308 -0
  208. package/dist/internal/nodes/apiService.js.map +1 -0
  209. package/dist/internal/nodes/apiService.test.d.ts +1 -0
  210. package/dist/internal/nodes/apiService.test.js +344 -0
  211. package/dist/internal/nodes/apiService.test.js.map +1 -0
  212. package/dist/internal/nodes/cache.d.ts +57 -0
  213. package/dist/internal/nodes/cache.js +226 -0
  214. package/dist/internal/nodes/cache.js.map +1 -0
  215. package/dist/internal/nodes/cache.test.d.ts +1 -0
  216. package/dist/internal/nodes/cache.test.js +160 -0
  217. package/dist/internal/nodes/cache.test.js.map +1 -0
  218. package/dist/internal/nodes/cryptoCache.d.ts +16 -0
  219. package/dist/internal/nodes/cryptoCache.js +50 -0
  220. package/dist/internal/nodes/cryptoCache.js.map +1 -0
  221. package/dist/internal/nodes/cryptoCache.test.d.ts +1 -0
  222. package/dist/internal/nodes/cryptoCache.test.js +79 -0
  223. package/dist/internal/nodes/cryptoCache.test.js.map +1 -0
  224. package/dist/internal/nodes/cryptoService.d.ts +75 -0
  225. package/dist/internal/nodes/cryptoService.js +409 -0
  226. package/dist/internal/nodes/cryptoService.js.map +1 -0
  227. package/dist/internal/nodes/cryptoService.test.d.ts +1 -0
  228. package/dist/internal/nodes/cryptoService.test.js +698 -0
  229. package/dist/internal/nodes/cryptoService.test.js.map +1 -0
  230. package/dist/internal/nodes/events.d.ts +91 -0
  231. package/dist/internal/nodes/events.js +243 -0
  232. package/dist/internal/nodes/events.js.map +1 -0
  233. package/dist/internal/nodes/events.test.d.ts +1 -0
  234. package/dist/internal/nodes/events.test.js +318 -0
  235. package/dist/internal/nodes/events.test.js.map +1 -0
  236. package/dist/internal/nodes/extendedAttributes.d.ts +23 -0
  237. package/dist/internal/nodes/extendedAttributes.js +117 -0
  238. package/dist/internal/nodes/extendedAttributes.js.map +1 -0
  239. package/dist/internal/nodes/extendedAttributes.test.d.ts +1 -0
  240. package/dist/internal/nodes/extendedAttributes.test.js +176 -0
  241. package/dist/internal/nodes/extendedAttributes.test.js.map +1 -0
  242. package/dist/internal/nodes/index.d.ts +26 -0
  243. package/dist/internal/nodes/index.js +40 -0
  244. package/dist/internal/nodes/index.js.map +1 -0
  245. package/dist/internal/nodes/index.test.d.ts +1 -0
  246. package/dist/internal/nodes/index.test.js +112 -0
  247. package/dist/internal/nodes/index.test.js.map +1 -0
  248. package/dist/internal/nodes/interface.d.ts +135 -0
  249. package/dist/internal/nodes/interface.js +3 -0
  250. package/dist/internal/nodes/interface.js.map +1 -0
  251. package/dist/internal/nodes/mediaTypes.d.ts +2 -0
  252. package/dist/internal/nodes/mediaTypes.js +13 -0
  253. package/dist/internal/nodes/mediaTypes.js.map +1 -0
  254. package/dist/internal/nodes/nodesAccess.d.ts +49 -0
  255. package/dist/internal/nodes/nodesAccess.js +332 -0
  256. package/dist/internal/nodes/nodesAccess.js.map +1 -0
  257. package/dist/internal/nodes/nodesAccess.test.d.ts +1 -0
  258. package/dist/internal/nodes/nodesAccess.test.js +487 -0
  259. package/dist/internal/nodes/nodesAccess.test.js.map +1 -0
  260. package/dist/internal/nodes/nodesManagement.d.ts +33 -0
  261. package/dist/internal/nodes/nodesManagement.js +222 -0
  262. package/dist/internal/nodes/nodesManagement.js.map +1 -0
  263. package/dist/internal/nodes/nodesManagement.test.d.ts +1 -0
  264. package/dist/internal/nodes/nodesManagement.test.js +178 -0
  265. package/dist/internal/nodes/nodesManagement.test.js.map +1 -0
  266. package/dist/internal/nodes/nodesRevisions.d.ts +18 -0
  267. package/dist/internal/nodes/nodesRevisions.js +55 -0
  268. package/dist/internal/nodes/nodesRevisions.js.map +1 -0
  269. package/dist/internal/nodes/validations.d.ts +4 -0
  270. package/dist/internal/nodes/validations.js +21 -0
  271. package/dist/internal/nodes/validations.js.map +1 -0
  272. package/dist/internal/photos/albums.d.ts +13 -0
  273. package/dist/internal/photos/albums.js +30 -0
  274. package/dist/internal/photos/albums.js.map +1 -0
  275. package/dist/internal/photos/apiService.d.ts +8 -0
  276. package/dist/internal/photos/apiService.js +18 -0
  277. package/dist/internal/photos/apiService.js.map +1 -0
  278. package/dist/internal/photos/cache.d.ts +6 -0
  279. package/dist/internal/photos/cache.js +15 -0
  280. package/dist/internal/photos/cache.js.map +1 -0
  281. package/dist/internal/photos/index.d.ts +9 -0
  282. package/dist/internal/photos/index.js +18 -0
  283. package/dist/internal/photos/index.js.map +1 -0
  284. package/dist/internal/photos/interface.d.ts +6 -0
  285. package/dist/internal/photos/interface.js +3 -0
  286. package/dist/internal/photos/interface.js.map +1 -0
  287. package/dist/internal/photos/photosTimeline.d.ts +10 -0
  288. package/dist/internal/photos/photosTimeline.js +20 -0
  289. package/dist/internal/photos/photosTimeline.js.map +1 -0
  290. package/dist/internal/sdkEvents.d.ts +12 -0
  291. package/dist/internal/sdkEvents.js +44 -0
  292. package/dist/internal/sdkEvents.js.map +1 -0
  293. package/dist/internal/sdkEvents.test.d.ts +1 -0
  294. package/dist/internal/sdkEvents.test.js +45 -0
  295. package/dist/internal/sdkEvents.test.js.map +1 -0
  296. package/dist/internal/shares/apiService.d.ts +51 -0
  297. package/dist/internal/shares/apiService.js +128 -0
  298. package/dist/internal/shares/apiService.js.map +1 -0
  299. package/dist/internal/shares/cache.d.ts +15 -0
  300. package/dist/internal/shares/cache.js +63 -0
  301. package/dist/internal/shares/cache.js.map +1 -0
  302. package/dist/internal/shares/cache.test.d.ts +1 -0
  303. package/dist/internal/shares/cache.test.js +54 -0
  304. package/dist/internal/shares/cache.test.js.map +1 -0
  305. package/dist/internal/shares/cryptoCache.d.ts +20 -0
  306. package/dist/internal/shares/cryptoCache.js +35 -0
  307. package/dist/internal/shares/cryptoCache.js.map +1 -0
  308. package/dist/internal/shares/cryptoCache.test.d.ts +1 -0
  309. package/dist/internal/shares/cryptoCache.test.js +58 -0
  310. package/dist/internal/shares/cryptoCache.test.js.map +1 -0
  311. package/dist/internal/shares/cryptoService.d.ts +42 -0
  312. package/dist/internal/shares/cryptoService.js +126 -0
  313. package/dist/internal/shares/cryptoService.js.map +1 -0
  314. package/dist/internal/shares/cryptoService.test.d.ts +1 -0
  315. package/dist/internal/shares/cryptoService.test.js +120 -0
  316. package/dist/internal/shares/cryptoService.test.js.map +1 -0
  317. package/dist/internal/shares/index.d.ts +15 -0
  318. package/dist/internal/shares/index.js +26 -0
  319. package/dist/internal/shares/index.js.map +1 -0
  320. package/dist/internal/shares/interface.d.ts +94 -0
  321. package/dist/internal/shares/interface.js +11 -0
  322. package/dist/internal/shares/interface.js.map +1 -0
  323. package/dist/internal/shares/manager.d.ts +68 -0
  324. package/dist/internal/shares/manager.js +186 -0
  325. package/dist/internal/shares/manager.js.map +1 -0
  326. package/dist/internal/shares/manager.test.d.ts +1 -0
  327. package/dist/internal/shares/manager.test.js +176 -0
  328. package/dist/internal/shares/manager.test.js.map +1 -0
  329. package/dist/internal/sharing/apiService.d.ts +80 -0
  330. package/dist/internal/sharing/apiService.js +325 -0
  331. package/dist/internal/sharing/apiService.js.map +1 -0
  332. package/dist/internal/sharing/cache.d.ts +37 -0
  333. package/dist/internal/sharing/cache.js +105 -0
  334. package/dist/internal/sharing/cache.js.map +1 -0
  335. package/dist/internal/sharing/cache.test.d.ts +1 -0
  336. package/dist/internal/sharing/cache.test.js +82 -0
  337. package/dist/internal/sharing/cache.test.js.map +1 -0
  338. package/dist/internal/sharing/cryptoService.d.ts +112 -0
  339. package/dist/internal/sharing/cryptoService.js +269 -0
  340. package/dist/internal/sharing/cryptoService.js.map +1 -0
  341. package/dist/internal/sharing/events.d.ts +57 -0
  342. package/dist/internal/sharing/events.js +153 -0
  343. package/dist/internal/sharing/events.js.map +1 -0
  344. package/dist/internal/sharing/events.test.d.ts +1 -0
  345. package/dist/internal/sharing/events.test.js +246 -0
  346. package/dist/internal/sharing/events.test.js.map +1 -0
  347. package/dist/internal/sharing/index.d.ts +20 -0
  348. package/dist/internal/sharing/index.js +30 -0
  349. package/dist/internal/sharing/index.js.map +1 -0
  350. package/dist/internal/sharing/interface.d.ts +169 -0
  351. package/dist/internal/sharing/interface.js +9 -0
  352. package/dist/internal/sharing/interface.js.map +1 -0
  353. package/dist/internal/sharing/sharingAccess.d.ts +32 -0
  354. package/dist/internal/sharing/sharingAccess.js +119 -0
  355. package/dist/internal/sharing/sharingAccess.js.map +1 -0
  356. package/dist/internal/sharing/sharingAccess.test.d.ts +1 -0
  357. package/dist/internal/sharing/sharingAccess.test.js +84 -0
  358. package/dist/internal/sharing/sharingAccess.test.js.map +1 -0
  359. package/dist/internal/sharing/sharingManagement.d.ts +43 -0
  360. package/dist/internal/sharing/sharingManagement.js +439 -0
  361. package/dist/internal/sharing/sharingManagement.js.map +1 -0
  362. package/dist/internal/sharing/sharingManagement.test.d.ts +1 -0
  363. package/dist/internal/sharing/sharingManagement.test.js +788 -0
  364. package/dist/internal/sharing/sharingManagement.test.js.map +1 -0
  365. package/dist/internal/uids.d.ts +38 -0
  366. package/dist/internal/uids.js +85 -0
  367. package/dist/internal/uids.js.map +1 -0
  368. package/dist/internal/upload/apiService.d.ts +65 -0
  369. package/dist/internal/upload/apiService.js +137 -0
  370. package/dist/internal/upload/apiService.js.map +1 -0
  371. package/dist/internal/upload/blockVerifier.d.ts +16 -0
  372. package/dist/internal/upload/blockVerifier.js +33 -0
  373. package/dist/internal/upload/blockVerifier.js.map +1 -0
  374. package/dist/internal/upload/chunkStreamReader.d.ts +13 -0
  375. package/dist/internal/upload/chunkStreamReader.js +46 -0
  376. package/dist/internal/upload/chunkStreamReader.js.map +1 -0
  377. package/dist/internal/upload/chunkStreamReader.test.d.ts +1 -0
  378. package/dist/internal/upload/chunkStreamReader.test.js +75 -0
  379. package/dist/internal/upload/chunkStreamReader.test.js.map +1 -0
  380. package/dist/internal/upload/controller.d.ts +8 -0
  381. package/dist/internal/upload/controller.js +25 -0
  382. package/dist/internal/upload/controller.js.map +1 -0
  383. package/dist/internal/upload/cryptoService.d.ts +29 -0
  384. package/dist/internal/upload/cryptoService.js +104 -0
  385. package/dist/internal/upload/cryptoService.js.map +1 -0
  386. package/dist/internal/upload/digests.d.ts +8 -0
  387. package/dist/internal/upload/digests.js +22 -0
  388. package/dist/internal/upload/digests.js.map +1 -0
  389. package/dist/internal/upload/fileUploader.d.ts +65 -0
  390. package/dist/internal/upload/fileUploader.js +463 -0
  391. package/dist/internal/upload/fileUploader.js.map +1 -0
  392. package/dist/internal/upload/fileUploader.test.d.ts +1 -0
  393. package/dist/internal/upload/fileUploader.test.js +393 -0
  394. package/dist/internal/upload/fileUploader.test.js.map +1 -0
  395. package/dist/internal/upload/index.d.ts +16 -0
  396. package/dist/internal/upload/index.js +77 -0
  397. package/dist/internal/upload/index.js.map +1 -0
  398. package/dist/internal/upload/interface.d.ts +117 -0
  399. package/dist/internal/upload/interface.js +3 -0
  400. package/dist/internal/upload/interface.js.map +1 -0
  401. package/dist/internal/upload/manager.d.ts +31 -0
  402. package/dist/internal/upload/manager.js +250 -0
  403. package/dist/internal/upload/manager.js.map +1 -0
  404. package/dist/internal/upload/manager.test.d.ts +1 -0
  405. package/dist/internal/upload/manager.test.js +349 -0
  406. package/dist/internal/upload/manager.test.js.map +1 -0
  407. package/dist/internal/upload/queue.d.ts +5 -0
  408. package/dist/internal/upload/queue.js +32 -0
  409. package/dist/internal/upload/queue.js.map +1 -0
  410. package/dist/internal/upload/telemetry.d.ts +15 -0
  411. package/dist/internal/upload/telemetry.js +111 -0
  412. package/dist/internal/upload/telemetry.js.map +1 -0
  413. package/dist/internal/upload/telemetry.test.d.ts +1 -0
  414. package/dist/internal/upload/telemetry.test.js +107 -0
  415. package/dist/internal/upload/telemetry.test.js.map +1 -0
  416. package/dist/internal/utils.d.ts +1 -0
  417. package/dist/internal/utils.js +13 -0
  418. package/dist/internal/utils.js.map +1 -0
  419. package/dist/internal/wait.d.ts +3 -0
  420. package/dist/internal/wait.js +28 -0
  421. package/dist/internal/wait.js.map +1 -0
  422. package/dist/internal/wait.test.d.ts +1 -0
  423. package/dist/internal/wait.test.js +21 -0
  424. package/dist/internal/wait.test.js.map +1 -0
  425. package/dist/protonDriveClient.d.ts +593 -0
  426. package/dist/protonDriveClient.js +768 -0
  427. package/dist/protonDriveClient.js.map +1 -0
  428. package/dist/protonDrivePhotosClient.d.ts +16 -0
  429. package/dist/protonDrivePhotosClient.js +46 -0
  430. package/dist/protonDrivePhotosClient.js.map +1 -0
  431. package/dist/telemetry.d.ts +187 -0
  432. package/dist/telemetry.js +297 -0
  433. package/dist/telemetry.js.map +1 -0
  434. package/dist/tests/logger.d.ts +2 -0
  435. package/dist/tests/logger.js +12 -0
  436. package/dist/tests/logger.js.map +1 -0
  437. package/dist/tests/telemetry.d.ts +2 -0
  438. package/dist/tests/telemetry.js +11 -0
  439. package/dist/tests/telemetry.js.map +1 -0
  440. package/dist/transformers.d.ts +17 -0
  441. package/dist/transformers.js +77 -0
  442. package/dist/transformers.js.map +1 -0
  443. package/dist/version.d.ts +1 -0
  444. package/dist/version.js +6 -0
  445. package/dist/version.js.map +1 -0
  446. package/package.json +49 -0
  447. package/src/cache/index.ts +2 -0
  448. package/src/cache/interface.ts +104 -0
  449. package/src/cache/memoryCache.test.ts +150 -0
  450. package/src/cache/memoryCache.ts +85 -0
  451. package/src/config.ts +9 -0
  452. package/src/crypto/driveCrypto.test.ts +45 -0
  453. package/src/crypto/driveCrypto.ts +696 -0
  454. package/src/crypto/hmac.ts +46 -0
  455. package/src/crypto/index.ts +6 -0
  456. package/src/crypto/interface.ts +230 -0
  457. package/src/crypto/openPGPCrypto.ts +398 -0
  458. package/src/crypto/utils.ts +40 -0
  459. package/src/errors.ts +168 -0
  460. package/src/index.ts +30 -0
  461. package/src/interface/account.ts +38 -0
  462. package/src/interface/author.ts +29 -0
  463. package/src/interface/devices.ts +21 -0
  464. package/src/interface/download.ts +32 -0
  465. package/src/interface/events.ts +30 -0
  466. package/src/interface/httpClient.ts +42 -0
  467. package/src/interface/index.ts +46 -0
  468. package/src/interface/nodes.ts +168 -0
  469. package/src/interface/result.ts +11 -0
  470. package/src/interface/sharing.ts +87 -0
  471. package/src/interface/telemetry.ts +107 -0
  472. package/src/interface/thumbnail.ts +14 -0
  473. package/src/interface/upload.ts +19 -0
  474. package/src/internal/apiService/apiService.test.ts +285 -0
  475. package/src/internal/apiService/apiService.ts +353 -0
  476. package/src/internal/apiService/coreTypes.ts +24439 -0
  477. package/src/internal/apiService/driveTypes.ts +11841 -0
  478. package/src/internal/apiService/errorCodes.ts +38 -0
  479. package/src/internal/apiService/errors.test.ts +63 -0
  480. package/src/internal/apiService/errors.ts +91 -0
  481. package/src/internal/apiService/index.ts +7 -0
  482. package/src/internal/apiService/observerStream.ts +10 -0
  483. package/src/internal/apiService/transformers.ts +45 -0
  484. package/src/internal/batchLoading.test.ts +58 -0
  485. package/src/internal/batchLoading.ts +74 -0
  486. package/src/internal/devices/apiService.ts +142 -0
  487. package/src/internal/devices/cryptoService.ts +65 -0
  488. package/src/internal/devices/index.ts +31 -0
  489. package/src/internal/devices/interface.ts +28 -0
  490. package/src/internal/devices/manager.test.ts +129 -0
  491. package/src/internal/devices/manager.ts +113 -0
  492. package/src/internal/download/apiService.ts +145 -0
  493. package/src/internal/download/controller.ts +22 -0
  494. package/src/internal/download/cryptoService.ts +96 -0
  495. package/src/internal/download/fileDownloader.test.ts +381 -0
  496. package/src/internal/download/fileDownloader.ts +266 -0
  497. package/src/internal/download/index.ts +122 -0
  498. package/src/internal/download/interface.ts +38 -0
  499. package/src/internal/download/queue.ts +30 -0
  500. package/src/internal/download/telemetry.test.ts +134 -0
  501. package/src/internal/download/telemetry.ts +115 -0
  502. package/src/internal/download/thumbnailDownloader.test.ts +226 -0
  503. package/src/internal/download/thumbnailDownloader.ts +250 -0
  504. package/src/internal/errors.test.ts +21 -0
  505. package/src/internal/errors.ts +28 -0
  506. package/src/internal/events/apiService.ts +87 -0
  507. package/src/internal/events/cache.test.ts +47 -0
  508. package/src/internal/events/cache.ts +80 -0
  509. package/src/internal/events/coreEventManager.ts +69 -0
  510. package/src/internal/events/eventManager.test.ts +139 -0
  511. package/src/internal/events/eventManager.ts +168 -0
  512. package/src/internal/events/index.ts +131 -0
  513. package/src/internal/events/interface.ts +51 -0
  514. package/src/internal/events/volumeEventManager.ts +74 -0
  515. package/src/internal/nodes/apiService.test.ts +394 -0
  516. package/src/internal/nodes/apiService.ts +455 -0
  517. package/src/internal/nodes/cache.test.ts +197 -0
  518. package/src/internal/nodes/cache.ts +240 -0
  519. package/src/internal/nodes/cryptoCache.test.ts +92 -0
  520. package/src/internal/nodes/cryptoCache.ts +47 -0
  521. package/src/internal/nodes/cryptoService.test.ts +814 -0
  522. package/src/internal/nodes/cryptoService.ts +550 -0
  523. package/src/internal/nodes/events.test.ts +383 -0
  524. package/src/internal/nodes/events.ts +271 -0
  525. package/src/internal/nodes/extendedAttributes.test.ts +177 -0
  526. package/src/internal/nodes/extendedAttributes.ts +180 -0
  527. package/src/internal/nodes/index.test.ts +135 -0
  528. package/src/internal/nodes/index.ts +52 -0
  529. package/src/internal/nodes/interface.ts +152 -0
  530. package/src/internal/nodes/mediaTypes.ts +10 -0
  531. package/src/internal/nodes/nodesAccess.test.ts +555 -0
  532. package/src/internal/nodes/nodesAccess.ts +360 -0
  533. package/src/internal/nodes/nodesManagement.test.ts +221 -0
  534. package/src/internal/nodes/nodesManagement.ts +272 -0
  535. package/src/internal/nodes/nodesRevisions.ts +58 -0
  536. package/src/internal/nodes/validations.ts +26 -0
  537. package/src/internal/photos/albums.ts +29 -0
  538. package/src/internal/photos/apiService.ts +16 -0
  539. package/src/internal/photos/cache.ts +11 -0
  540. package/src/internal/photos/index.ts +23 -0
  541. package/src/internal/photos/interface.ts +7 -0
  542. package/src/internal/photos/photosTimeline.ts +18 -0
  543. package/src/internal/sdkEvents.test.ts +55 -0
  544. package/src/internal/sdkEvents.ts +52 -0
  545. package/src/internal/shares/apiService.ts +176 -0
  546. package/src/internal/shares/cache.test.ts +58 -0
  547. package/src/internal/shares/cache.ts +64 -0
  548. package/src/internal/shares/cryptoCache.test.ts +70 -0
  549. package/src/internal/shares/cryptoCache.ts +35 -0
  550. package/src/internal/shares/cryptoService.test.ts +137 -0
  551. package/src/internal/shares/cryptoService.ts +143 -0
  552. package/src/internal/shares/index.ts +35 -0
  553. package/src/internal/shares/interface.ts +104 -0
  554. package/src/internal/shares/manager.test.ts +210 -0
  555. package/src/internal/shares/manager.ts +213 -0
  556. package/src/internal/sharing/apiService.ts +483 -0
  557. package/src/internal/sharing/cache.test.ts +99 -0
  558. package/src/internal/sharing/cache.ts +109 -0
  559. package/src/internal/sharing/cryptoService.ts +378 -0
  560. package/src/internal/sharing/events.test.ts +268 -0
  561. package/src/internal/sharing/events.ts +166 -0
  562. package/src/internal/sharing/index.ts +43 -0
  563. package/src/internal/sharing/interface.ts +177 -0
  564. package/src/internal/sharing/sharingAccess.test.ts +102 -0
  565. package/src/internal/sharing/sharingAccess.ts +133 -0
  566. package/src/internal/sharing/sharingManagement.test.ts +895 -0
  567. package/src/internal/sharing/sharingManagement.ts +521 -0
  568. package/src/internal/uids.ts +83 -0
  569. package/src/internal/upload/apiService.ts +243 -0
  570. package/src/internal/upload/blockVerifier.ts +40 -0
  571. package/src/internal/upload/chunkStreamReader.test.ts +89 -0
  572. package/src/internal/upload/chunkStreamReader.ts +49 -0
  573. package/src/internal/upload/controller.ts +25 -0
  574. package/src/internal/upload/cryptoService.ts +162 -0
  575. package/src/internal/upload/digests.ts +18 -0
  576. package/src/internal/upload/fileUploader.test.ts +513 -0
  577. package/src/internal/upload/fileUploader.ts +576 -0
  578. package/src/internal/upload/index.ts +126 -0
  579. package/src/internal/upload/interface.ts +128 -0
  580. package/src/internal/upload/manager.test.ts +390 -0
  581. package/src/internal/upload/manager.ts +320 -0
  582. package/src/internal/upload/queue.ts +31 -0
  583. package/src/internal/upload/telemetry.test.ts +129 -0
  584. package/src/internal/upload/telemetry.ts +121 -0
  585. package/src/internal/utils.ts +9 -0
  586. package/src/internal/wait.test.ts +21 -0
  587. package/src/internal/wait.ts +26 -0
  588. package/src/protonDriveClient.ts +861 -0
  589. package/src/protonDrivePhotosClient.ts +56 -0
  590. package/src/telemetry.ts +346 -0
  591. package/src/tests/logger.ts +10 -0
  592. package/src/tests/telemetry.ts +9 -0
  593. package/src/transformers.ts +98 -0
  594. package/src/version.ts +4 -0
@@ -0,0 +1,788 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const logger_1 = require("../../tests/logger");
4
+ const interface_1 = require("../../interface");
5
+ const sharingManagement_1 = require("./sharingManagement");
6
+ describe("SharingManagement", () => {
7
+ let apiService;
8
+ let cryptoService;
9
+ let accountService;
10
+ let sharesService;
11
+ let nodesService;
12
+ let nodesEvents;
13
+ let sharingManagement;
14
+ beforeEach(() => {
15
+ // @ts-expect-error No need to implement all methods for mocking
16
+ apiService = {
17
+ createStandardShare: jest.fn().mockReturnValue("newShareId"),
18
+ getShareInvitations: jest.fn().mockResolvedValue([]),
19
+ getShareExternalInvitations: jest.fn().mockResolvedValue([]),
20
+ getShareMembers: jest.fn().mockResolvedValue([]),
21
+ inviteProtonUser: jest.fn().mockImplementation((_, invitation) => ({
22
+ ...invitation,
23
+ uid: "created-invitation",
24
+ })),
25
+ updateInvitation: jest.fn(),
26
+ deleteInvitation: jest.fn(),
27
+ inviteExternalUser: jest.fn().mockImplementation((_, invitation) => ({
28
+ ...invitation,
29
+ uid: "created-external-invitation",
30
+ state: interface_1.NonProtonInvitationState.Pending,
31
+ })),
32
+ updateExternalInvitation: jest.fn(),
33
+ deleteExternalInvitation: jest.fn(),
34
+ updateMember: jest.fn(),
35
+ removeMember: jest.fn(),
36
+ getPublicLink: jest.fn().mockResolvedValue(undefined),
37
+ removePublicLink: jest.fn(),
38
+ deleteShare: jest.fn(),
39
+ resendInvitationEmail: jest.fn(),
40
+ resendExternalInvitationEmail: jest.fn(),
41
+ createPublicLink: jest.fn().mockResolvedValue({
42
+ uid: "publicLinkUid",
43
+ publicUrl: "publicLinkUrl",
44
+ }),
45
+ updatePublicLink: jest.fn(),
46
+ };
47
+ // @ts-expect-error No need to implement all methods for mocking
48
+ cryptoService = {
49
+ generateShareKeys: jest.fn().mockResolvedValue({ shareKey: { encrypted: "encrypted-key", decrypted: { passphraseSessionKey: "pass-session-key", } } }),
50
+ decryptShare: jest.fn().mockImplementation((share) => share),
51
+ decryptInvitation: jest.fn().mockImplementation((invitation) => invitation),
52
+ decryptExternalInvitation: jest.fn().mockImplementation((invitation) => invitation),
53
+ decryptMember: jest.fn().mockImplementation((member) => member),
54
+ encryptInvitation: jest.fn().mockImplementation(() => { }),
55
+ encryptExternalInvitation: jest.fn().mockImplementation((invitation) => ({
56
+ ...invitation,
57
+ base64ExternalInvitationSignature: "extenral-signature",
58
+ })),
59
+ decryptPublicLink: jest.fn().mockImplementation((publicLink) => publicLink),
60
+ generatePublicLinkPassword: jest.fn().mockResolvedValue("generatedPassword"),
61
+ encryptPublicLink: jest.fn().mockImplementation(() => ({
62
+ crypto: "publicLinkCrypto",
63
+ srp: "publicLinkSrp",
64
+ })),
65
+ };
66
+ // @ts-expect-error No need to implement all methods for mocking
67
+ accountService = {
68
+ hasProtonAccount: jest.fn().mockResolvedValue(true),
69
+ };
70
+ // @ts-expect-error No need to implement all methods for mocking
71
+ sharesService = {
72
+ loadEncryptedShare: jest.fn().mockResolvedValue({ id: "shareId", addressId: "addressId", creatorEmail: "address@example.com", passphraseSessionKey: "sharePassphraseSessionKey" }),
73
+ getContextShareMemberEmailKey: jest.fn().mockResolvedValue({ email: "volume-email", addressId: "addressId", addressKey: "volume-key" }),
74
+ };
75
+ // @ts-expect-error No need to implement all methods for mocking
76
+ nodesService = {
77
+ getNode: jest.fn().mockImplementation((nodeUid) => ({ nodeUid, shareId: "shareId", name: { ok: true, value: "name" } })),
78
+ getNodeKeys: jest.fn().mockImplementation((nodeUid) => ({ key: "node-key" })),
79
+ getNodePrivateAndSessionKeys: jest.fn().mockImplementation((nodeUid) => ({})),
80
+ getRootNodeEmailKey: jest.fn().mockResolvedValue({ email: "volume-email", addressKey: "volume-key" }),
81
+ };
82
+ nodesEvents = {
83
+ nodeUpdated: jest.fn(),
84
+ };
85
+ sharingManagement = new sharingManagement_1.SharingManagement((0, logger_1.getMockLogger)(), apiService, cryptoService, accountService, sharesService, nodesService, nodesEvents);
86
+ });
87
+ describe("getSharingInfo", () => {
88
+ it("should return empty sharing info for unshared node", async () => {
89
+ nodesService.getNode = jest.fn().mockResolvedValue({ nodeUid: "nodeUid", shareId: undefined });
90
+ const sharingInfo = await sharingManagement.getSharingInfo("nodeUid");
91
+ expect(sharingInfo).toEqual(undefined);
92
+ expect(apiService.getShareInvitations).not.toHaveBeenCalled();
93
+ expect(apiService.getShareExternalInvitations).not.toHaveBeenCalled();
94
+ expect(apiService.getShareMembers).not.toHaveBeenCalled();
95
+ });
96
+ it("should return invitations", async () => {
97
+ const invitation = { uid: "invitaiton", addedByEmail: "email" };
98
+ apiService.getShareInvitations = jest.fn().mockResolvedValue([
99
+ invitation,
100
+ ]);
101
+ const sharingInfo = await sharingManagement.getSharingInfo("nodeUid");
102
+ expect(sharingInfo).toEqual({
103
+ protonInvitations: [invitation],
104
+ nonProtonInvitations: [],
105
+ members: [],
106
+ publicLink: undefined,
107
+ });
108
+ expect(cryptoService.decryptInvitation).toHaveBeenCalledWith(invitation);
109
+ });
110
+ it("should return external invitations", async () => {
111
+ const externalInvitation = { uid: "external-invitation", addedByEmail: "email" };
112
+ apiService.getShareExternalInvitations = jest.fn().mockResolvedValue([
113
+ externalInvitation,
114
+ ]);
115
+ const sharingInfo = await sharingManagement.getSharingInfo("nodeUid");
116
+ expect(sharingInfo).toEqual({
117
+ protonInvitations: [],
118
+ nonProtonInvitations: [externalInvitation],
119
+ members: [],
120
+ publicLink: undefined,
121
+ });
122
+ expect(cryptoService.decryptExternalInvitation).toHaveBeenCalledWith(externalInvitation);
123
+ });
124
+ it("should return members", async () => {
125
+ const member = { uid: "member", addedByEmail: "email" };
126
+ apiService.getShareMembers = jest.fn().mockResolvedValue([
127
+ member,
128
+ ]);
129
+ const sharingInfo = await sharingManagement.getSharingInfo("nodeUid");
130
+ expect(sharingInfo).toEqual({
131
+ protonInvitations: [],
132
+ nonProtonInvitations: [],
133
+ members: [member],
134
+ publicLink: undefined,
135
+ });
136
+ expect(cryptoService.decryptMember).toHaveBeenCalledWith(member);
137
+ });
138
+ it("should return public link", async () => {
139
+ const publicLink = {
140
+ uid: 'shared~publicLink',
141
+ };
142
+ apiService.getPublicLink = jest.fn().mockResolvedValue(publicLink);
143
+ const sharingInfo = await sharingManagement.getSharingInfo("nodeUid");
144
+ expect(sharingInfo).toEqual({
145
+ protonInvitations: [],
146
+ nonProtonInvitations: [],
147
+ members: [],
148
+ publicLink: publicLink,
149
+ });
150
+ expect(cryptoService.decryptPublicLink).toHaveBeenCalledWith(publicLink);
151
+ });
152
+ });
153
+ describe("shareNode with share creation", () => {
154
+ const nodeUid = "volumeId~nodeUid";
155
+ it("should create share if no exists", async () => {
156
+ nodesService.getNode = jest.fn().mockImplementation((nodeUid) => ({ nodeUid, parentUid: 'parentUid', name: { ok: true, value: "name" } }));
157
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: ["email"] });
158
+ expect(sharingInfo).toEqual({
159
+ protonInvitations: [{
160
+ uid: "created-invitation",
161
+ addedByEmail: { ok: true, value: "volume-email" },
162
+ inviteeEmail: "email",
163
+ role: "viewer",
164
+ }],
165
+ nonProtonInvitations: [],
166
+ members: [],
167
+ publicLink: undefined,
168
+ });
169
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
170
+ expect(apiService.inviteProtonUser).toHaveBeenCalled();
171
+ expect(nodesEvents.nodeUpdated).toHaveBeenCalledWith({
172
+ uid: nodeUid,
173
+ shareId: "newShareId",
174
+ isShared: true,
175
+ });
176
+ });
177
+ });
178
+ describe("shareNode with share re-use", () => {
179
+ const nodeUid = "volumeId~nodeUid";
180
+ let invitation;
181
+ let externalInvitation;
182
+ let member;
183
+ beforeEach(async () => {
184
+ invitation = {
185
+ uid: "invitation",
186
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
187
+ inviteeEmail: "internal-email",
188
+ role: interface_1.MemberRole.Viewer,
189
+ invitationTime: new Date(),
190
+ };
191
+ externalInvitation = {
192
+ uid: "external-invitation",
193
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
194
+ inviteeEmail: "external-email",
195
+ role: interface_1.MemberRole.Viewer,
196
+ invitationTime: new Date(),
197
+ state: interface_1.NonProtonInvitationState.Pending,
198
+ };
199
+ member = {
200
+ uid: "member",
201
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
202
+ inviteeEmail: "member-email",
203
+ role: interface_1.MemberRole.Viewer,
204
+ invitationTime: new Date(),
205
+ };
206
+ apiService.getShareInvitations = jest.fn().mockResolvedValue([
207
+ invitation,
208
+ ]);
209
+ apiService.getShareExternalInvitations = jest.fn().mockResolvedValue([
210
+ externalInvitation,
211
+ ]);
212
+ apiService.getShareMembers = jest.fn().mockResolvedValue([
213
+ member,
214
+ ]);
215
+ });
216
+ describe("invitations", () => {
217
+ beforeEach(() => {
218
+ accountService.hasProtonAccount = jest.fn().mockResolvedValue(true);
219
+ });
220
+ it("should share node with proton email with default role", async () => {
221
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: ["email"] });
222
+ expect(sharingInfo).toEqual({
223
+ protonInvitations: [invitation, {
224
+ uid: "created-invitation",
225
+ addedByEmail: { ok: true, value: "volume-email" },
226
+ inviteeEmail: "email",
227
+ role: "viewer",
228
+ }],
229
+ nonProtonInvitations: [externalInvitation],
230
+ members: [member],
231
+ publicLink: undefined,
232
+ });
233
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
234
+ expect(apiService.inviteProtonUser).toHaveBeenCalled();
235
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
236
+ });
237
+ it("should share node with proton email with specific role", async () => {
238
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "email", role: interface_1.MemberRole.Editor }] });
239
+ expect(sharingInfo).toEqual({
240
+ protonInvitations: [invitation, {
241
+ uid: "created-invitation",
242
+ addedByEmail: { ok: true, value: "volume-email" },
243
+ inviteeEmail: "email",
244
+ role: "editor",
245
+ }],
246
+ nonProtonInvitations: [externalInvitation],
247
+ members: [member],
248
+ publicLink: undefined,
249
+ });
250
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
251
+ expect(apiService.inviteProtonUser).toHaveBeenCalled();
252
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
253
+ });
254
+ it("should update existing role", async () => {
255
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "internal-email", role: interface_1.MemberRole.Editor }] });
256
+ expect(sharingInfo).toEqual({
257
+ protonInvitations: [{
258
+ ...invitation,
259
+ role: "editor",
260
+ }],
261
+ nonProtonInvitations: [externalInvitation],
262
+ members: [member],
263
+ publicLink: undefined,
264
+ });
265
+ expect(apiService.updateInvitation).toHaveBeenCalled();
266
+ expect(apiService.inviteProtonUser).not.toHaveBeenCalled();
267
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
268
+ });
269
+ it("should be no-op if no change", async () => {
270
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "internal-email", role: interface_1.MemberRole.Viewer }] });
271
+ expect(sharingInfo).toEqual({
272
+ protonInvitations: [invitation],
273
+ nonProtonInvitations: [externalInvitation],
274
+ members: [member],
275
+ publicLink: undefined,
276
+ });
277
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
278
+ expect(apiService.inviteProtonUser).not.toHaveBeenCalled();
279
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
280
+ });
281
+ });
282
+ describe("external invitations", () => {
283
+ beforeEach(() => {
284
+ accountService.hasProtonAccount = jest.fn().mockResolvedValue(false);
285
+ });
286
+ it("should share node with external email with default role", async () => {
287
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: ["email"] });
288
+ expect(sharingInfo).toEqual({
289
+ protonInvitations: [invitation],
290
+ nonProtonInvitations: [externalInvitation, {
291
+ uid: "created-external-invitation",
292
+ addedByEmail: { ok: true, value: "volume-email" },
293
+ inviteeEmail: "email",
294
+ role: "viewer",
295
+ state: "pending",
296
+ }],
297
+ members: [member],
298
+ publicLink: undefined,
299
+ });
300
+ expect(apiService.updateExternalInvitation).not.toHaveBeenCalled();
301
+ expect(apiService.inviteExternalUser).toHaveBeenCalled();
302
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
303
+ });
304
+ it("should share node with external email with specific role", async () => {
305
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "email", role: interface_1.MemberRole.Editor }] });
306
+ expect(sharingInfo).toEqual({
307
+ protonInvitations: [invitation],
308
+ nonProtonInvitations: [externalInvitation, {
309
+ uid: "created-external-invitation",
310
+ addedByEmail: { ok: true, value: "volume-email" },
311
+ inviteeEmail: "email",
312
+ role: "editor",
313
+ state: "pending",
314
+ }],
315
+ members: [member],
316
+ publicLink: undefined,
317
+ });
318
+ expect(apiService.updateExternalInvitation).not.toHaveBeenCalled();
319
+ expect(apiService.inviteExternalUser).toHaveBeenCalled();
320
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
321
+ });
322
+ it("should update existing role", async () => {
323
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "external-email", role: interface_1.MemberRole.Editor }] });
324
+ expect(sharingInfo).toEqual({
325
+ protonInvitations: [invitation],
326
+ nonProtonInvitations: [{
327
+ ...externalInvitation,
328
+ role: "editor",
329
+ }],
330
+ members: [member],
331
+ publicLink: undefined,
332
+ });
333
+ expect(apiService.updateExternalInvitation).toHaveBeenCalled();
334
+ expect(apiService.inviteExternalUser).not.toHaveBeenCalled();
335
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
336
+ });
337
+ it("should be no-op if no change", async () => {
338
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "external-email", role: interface_1.MemberRole.Viewer }] });
339
+ expect(sharingInfo).toEqual({
340
+ protonInvitations: [invitation],
341
+ nonProtonInvitations: [externalInvitation],
342
+ members: [member],
343
+ publicLink: undefined,
344
+ });
345
+ expect(apiService.updateExternalInvitation).not.toHaveBeenCalled();
346
+ expect(apiService.inviteExternalUser).not.toHaveBeenCalled();
347
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
348
+ });
349
+ });
350
+ describe("mix of internal and external invitations", () => {
351
+ beforeEach(() => {
352
+ accountService.hasProtonAccount = jest.fn()
353
+ .mockResolvedValueOnce(true)
354
+ .mockResolvedValueOnce(false);
355
+ });
356
+ it("should share node with proton and external email with default role", async () => {
357
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: ["email", "email2"] });
358
+ expect(sharingInfo).toEqual({
359
+ protonInvitations: [invitation, {
360
+ uid: "created-invitation",
361
+ addedByEmail: { ok: true, value: "volume-email" },
362
+ inviteeEmail: "email",
363
+ role: "viewer",
364
+ }],
365
+ nonProtonInvitations: [externalInvitation, {
366
+ uid: "created-external-invitation",
367
+ addedByEmail: { ok: true, value: "volume-email" },
368
+ inviteeEmail: "email2",
369
+ role: "viewer",
370
+ state: "pending",
371
+ }],
372
+ members: [member],
373
+ publicLink: undefined,
374
+ });
375
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
376
+ expect(apiService.inviteProtonUser).toHaveBeenCalledWith("shareId", expect.objectContaining({
377
+ inviteeEmail: "email",
378
+ }), expect.anything());
379
+ expect(apiService.inviteExternalUser).toHaveBeenCalledWith("shareId", expect.objectContaining({
380
+ inviteeEmail: "email2",
381
+ }), expect.anything());
382
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
383
+ });
384
+ });
385
+ describe("members", () => {
386
+ it("should update member via proton user", async () => {
387
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "member-email", role: interface_1.MemberRole.Editor }] });
388
+ expect(sharingInfo).toEqual({
389
+ protonInvitations: [invitation],
390
+ nonProtonInvitations: [externalInvitation],
391
+ members: [{
392
+ ...member,
393
+ role: "editor",
394
+ }],
395
+ publicLink: undefined,
396
+ });
397
+ expect(apiService.updateMember).toHaveBeenCalled();
398
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
399
+ expect(apiService.inviteProtonUser).not.toHaveBeenCalled();
400
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
401
+ });
402
+ it("should be no-op if no change via proton user", async () => {
403
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "member-email", role: interface_1.MemberRole.Viewer }] });
404
+ expect(sharingInfo).toEqual({
405
+ protonInvitations: [invitation],
406
+ nonProtonInvitations: [externalInvitation],
407
+ members: [member],
408
+ publicLink: undefined,
409
+ });
410
+ expect(apiService.updateMember).not.toHaveBeenCalled();
411
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
412
+ expect(apiService.inviteProtonUser).not.toHaveBeenCalled();
413
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
414
+ });
415
+ it("should update member via non-proton user", async () => {
416
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "member-email", role: interface_1.MemberRole.Editor }] });
417
+ expect(sharingInfo).toEqual({
418
+ protonInvitations: [invitation],
419
+ nonProtonInvitations: [externalInvitation],
420
+ members: [{
421
+ ...member,
422
+ role: "editor",
423
+ }],
424
+ publicLink: undefined,
425
+ });
426
+ expect(apiService.updateMember).toHaveBeenCalled();
427
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
428
+ expect(apiService.inviteProtonUser).not.toHaveBeenCalled();
429
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
430
+ });
431
+ it("should be no-op if no change via non-proton user", async () => {
432
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, { users: [{ email: "member-email", role: interface_1.MemberRole.Viewer }] });
433
+ expect(sharingInfo).toEqual({
434
+ protonInvitations: [invitation],
435
+ nonProtonInvitations: [externalInvitation],
436
+ members: [member],
437
+ publicLink: undefined,
438
+ });
439
+ expect(apiService.updateMember).not.toHaveBeenCalled();
440
+ expect(apiService.updateInvitation).not.toHaveBeenCalled();
441
+ expect(apiService.inviteProtonUser).not.toHaveBeenCalled();
442
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
443
+ });
444
+ });
445
+ describe("public link", () => {
446
+ it("should share node with public link", async () => {
447
+ jest.useFakeTimers();
448
+ jest.setSystemTime(new Date('2025-01-01'));
449
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, {
450
+ publicLink: {
451
+ role: interface_1.MemberRole.Viewer,
452
+ customPassword: undefined,
453
+ expiration: undefined,
454
+ },
455
+ });
456
+ expect(sharingInfo).toEqual({
457
+ protonInvitations: [invitation],
458
+ nonProtonInvitations: [externalInvitation],
459
+ members: [member],
460
+ publicLink: {
461
+ uid: "publicLinkUid",
462
+ role: interface_1.MemberRole.Viewer,
463
+ url: "publicLinkUrl#generatedPassword",
464
+ creationTime: new Date(),
465
+ expirationTime: undefined,
466
+ customPassword: undefined,
467
+ creatorEmail: "volume-email",
468
+ },
469
+ });
470
+ expect(cryptoService.generatePublicLinkPassword).toHaveBeenCalled();
471
+ expect(cryptoService.encryptPublicLink).toHaveBeenCalledWith("volume-email", "sharePassphraseSessionKey", "generatedPassword");
472
+ expect(apiService.createPublicLink).toHaveBeenCalledWith("shareId", expect.objectContaining({
473
+ role: interface_1.MemberRole.Viewer,
474
+ includesCustomPassword: false,
475
+ expirationDuration: undefined,
476
+ crypto: "publicLinkCrypto",
477
+ srp: "publicLinkSrp",
478
+ }));
479
+ });
480
+ it("should share node with custom password and expiration", async () => {
481
+ jest.useFakeTimers();
482
+ jest.setSystemTime(new Date('2025-01-01'));
483
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, {
484
+ publicLink: {
485
+ role: interface_1.MemberRole.Viewer,
486
+ customPassword: "customPassword",
487
+ expiration: new Date('2025-01-02'),
488
+ },
489
+ });
490
+ expect(sharingInfo).toEqual({
491
+ protonInvitations: [invitation],
492
+ nonProtonInvitations: [externalInvitation],
493
+ members: [member],
494
+ publicLink: {
495
+ uid: "publicLinkUid",
496
+ role: interface_1.MemberRole.Viewer,
497
+ url: "publicLinkUrl#generatedPassword",
498
+ creationTime: new Date(),
499
+ expirationTime: new Date('2025-01-02'),
500
+ customPassword: "customPassword",
501
+ creatorEmail: "volume-email",
502
+ },
503
+ });
504
+ expect(cryptoService.generatePublicLinkPassword).toHaveBeenCalled();
505
+ expect(cryptoService.encryptPublicLink).toHaveBeenCalledWith("volume-email", "sharePassphraseSessionKey", "generatedPasswordcustomPassword");
506
+ expect(apiService.createPublicLink).toHaveBeenCalledWith("shareId", expect.objectContaining({
507
+ role: interface_1.MemberRole.Viewer,
508
+ includesCustomPassword: true,
509
+ expirationDuration: 86400,
510
+ crypto: "publicLinkCrypto",
511
+ srp: "publicLinkSrp",
512
+ }));
513
+ });
514
+ it("should update public link with custom password and expiration", async () => {
515
+ jest.useFakeTimers();
516
+ jest.setSystemTime(new Date('2025-01-01'));
517
+ const publicLink = {
518
+ uid: 'publicLinkUid',
519
+ url: "publicLinkUrl#generatedpas", // Generated password must be 12 chararacters long.
520
+ creationTime: new Date('2025-01-01'),
521
+ role: interface_1.MemberRole.Viewer,
522
+ customPassword: undefined,
523
+ expirationTime: undefined,
524
+ creatorEmail: "publicLinkCreatorEmail",
525
+ };
526
+ apiService.getPublicLink = jest.fn().mockResolvedValue(publicLink);
527
+ const sharingInfo = await sharingManagement.shareNode(nodeUid, {
528
+ publicLink: {
529
+ role: interface_1.MemberRole.Editor,
530
+ customPassword: "customPassword",
531
+ expiration: new Date('2025-01-02'),
532
+ },
533
+ });
534
+ expect(sharingInfo).toEqual({
535
+ protonInvitations: [invitation],
536
+ nonProtonInvitations: [externalInvitation],
537
+ members: [member],
538
+ publicLink: {
539
+ uid: "publicLinkUid",
540
+ role: interface_1.MemberRole.Editor,
541
+ url: "publicLinkUrl#generatedpas",
542
+ creationTime: new Date('2025-01-01'),
543
+ expirationTime: new Date('2025-01-02'),
544
+ customPassword: "customPassword",
545
+ creatorEmail: "publicLinkCreatorEmail",
546
+ },
547
+ });
548
+ expect(cryptoService.encryptPublicLink).toHaveBeenCalledWith("publicLinkCreatorEmail", "sharePassphraseSessionKey", "generatedpascustomPassword");
549
+ expect(apiService.updatePublicLink).toHaveBeenCalledWith("publicLinkUid", expect.objectContaining({
550
+ role: interface_1.MemberRole.Editor,
551
+ includesCustomPassword: true,
552
+ expirationDuration: 86400,
553
+ crypto: "publicLinkCrypto",
554
+ srp: "publicLinkSrp",
555
+ }));
556
+ });
557
+ it("should not allow updating legacy public link", async () => {
558
+ apiService.getPublicLink = jest.fn().mockResolvedValue({
559
+ uid: 'publicLinkUid',
560
+ url: "publicLinkUrl#aaa", // Legacy public links doesn't have 12 chars.
561
+ });
562
+ await expect(sharingManagement.shareNode(nodeUid, {
563
+ publicLink: true,
564
+ })).rejects.toThrow("Legacy public link cannot be updated. Please re-create a new public link.");
565
+ });
566
+ it("should not allow updating legacy public link without generated password", async () => {
567
+ apiService.getPublicLink = jest.fn().mockResolvedValue({
568
+ uid: 'publicLinkUid',
569
+ url: "publicLinkUrl",
570
+ });
571
+ await expect(sharingManagement.shareNode(nodeUid, {
572
+ publicLink: true,
573
+ })).rejects.toThrow("Legacy public link cannot be updated. Please re-create a new public link.");
574
+ });
575
+ it("should not allow creating public link with expiration in the past", async () => {
576
+ jest.useFakeTimers();
577
+ jest.setSystemTime(new Date('2025-01-01'));
578
+ await expect(sharingManagement.shareNode(nodeUid, {
579
+ publicLink: {
580
+ role: interface_1.MemberRole.Viewer,
581
+ expiration: new Date('2024-01-01'),
582
+ },
583
+ })).rejects.toThrow("Expiration date cannot be in the past");
584
+ expect(apiService.createStandardShare).not.toHaveBeenCalled();
585
+ expect(apiService.createPublicLink).not.toHaveBeenCalled();
586
+ });
587
+ });
588
+ });
589
+ describe("unsahreNode", () => {
590
+ const nodeUid = "volumeId~nodeUid";
591
+ let invitation;
592
+ let externalInvitation;
593
+ let member;
594
+ let publicLink;
595
+ beforeEach(async () => {
596
+ invitation = {
597
+ uid: "invitation",
598
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
599
+ inviteeEmail: "internal-email",
600
+ role: interface_1.MemberRole.Viewer,
601
+ invitationTime: new Date(),
602
+ };
603
+ externalInvitation = {
604
+ uid: "external-invitation",
605
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
606
+ inviteeEmail: "external-email",
607
+ role: interface_1.MemberRole.Viewer,
608
+ invitationTime: new Date(),
609
+ state: interface_1.NonProtonInvitationState.Pending,
610
+ };
611
+ member = {
612
+ uid: "member",
613
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
614
+ inviteeEmail: "member-email",
615
+ role: interface_1.MemberRole.Viewer,
616
+ invitationTime: new Date(),
617
+ };
618
+ publicLink = {
619
+ uid: "publicLink",
620
+ creationTime: new Date(),
621
+ role: interface_1.MemberRole.Viewer,
622
+ url: "url",
623
+ };
624
+ apiService.getShareInvitations = jest.fn().mockResolvedValue([
625
+ invitation,
626
+ ]);
627
+ apiService.getShareExternalInvitations = jest.fn().mockResolvedValue([
628
+ externalInvitation,
629
+ ]);
630
+ apiService.getShareMembers = jest.fn().mockResolvedValue([
631
+ member,
632
+ ]);
633
+ apiService.getPublicLink = jest.fn().mockResolvedValue(publicLink);
634
+ });
635
+ it("should delete invitation", async () => {
636
+ const sharingInfo = await sharingManagement.unshareNode(nodeUid, { users: ["internal-email"] });
637
+ expect(sharingInfo).toEqual({
638
+ protonInvitations: [],
639
+ nonProtonInvitations: [externalInvitation],
640
+ members: [member],
641
+ publicLink,
642
+ });
643
+ expect(apiService.deleteShare).not.toHaveBeenCalled();
644
+ expect(apiService.deleteInvitation).toHaveBeenCalled();
645
+ expect(apiService.deleteExternalInvitation).not.toHaveBeenCalled();
646
+ expect(apiService.removeMember).not.toHaveBeenCalled();
647
+ expect(apiService.removePublicLink).not.toHaveBeenCalled();
648
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
649
+ });
650
+ it("should delete external invitation", async () => {
651
+ const sharingInfo = await sharingManagement.unshareNode(nodeUid, { users: ["external-email"] });
652
+ expect(sharingInfo).toEqual({
653
+ protonInvitations: [invitation],
654
+ nonProtonInvitations: [],
655
+ members: [member],
656
+ publicLink,
657
+ });
658
+ expect(apiService.deleteShare).not.toHaveBeenCalled();
659
+ expect(apiService.deleteInvitation).not.toHaveBeenCalled();
660
+ expect(apiService.deleteExternalInvitation).toHaveBeenCalled();
661
+ expect(apiService.removeMember).not.toHaveBeenCalled();
662
+ expect(apiService.removePublicLink).not.toHaveBeenCalled();
663
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
664
+ });
665
+ it("should remove member", async () => {
666
+ const sharingInfo = await sharingManagement.unshareNode(nodeUid, { users: ["member-email"] });
667
+ expect(sharingInfo).toEqual({
668
+ protonInvitations: [invitation],
669
+ nonProtonInvitations: [externalInvitation],
670
+ members: [],
671
+ publicLink,
672
+ });
673
+ expect(apiService.deleteShare).not.toHaveBeenCalled();
674
+ expect(apiService.deleteInvitation).not.toHaveBeenCalled();
675
+ expect(apiService.deleteExternalInvitation).not.toHaveBeenCalled();
676
+ expect(apiService.removeMember).toHaveBeenCalled();
677
+ expect(apiService.removePublicLink).not.toHaveBeenCalled();
678
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
679
+ });
680
+ it("should be no-op if not shared with email", async () => {
681
+ const sharingInfo = await sharingManagement.unshareNode(nodeUid, { users: ["non-existing-email"] });
682
+ expect(sharingInfo).toEqual({
683
+ protonInvitations: [invitation],
684
+ nonProtonInvitations: [externalInvitation],
685
+ members: [member],
686
+ publicLink,
687
+ });
688
+ expect(apiService.deleteShare).not.toHaveBeenCalled();
689
+ expect(apiService.deleteInvitation).not.toHaveBeenCalled();
690
+ expect(apiService.deleteExternalInvitation).not.toHaveBeenCalled();
691
+ expect(apiService.removeMember).not.toHaveBeenCalled();
692
+ expect(apiService.removePublicLink).not.toHaveBeenCalled();
693
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
694
+ });
695
+ it("should remove public link", async () => {
696
+ const sharingInfo = await sharingManagement.unshareNode(nodeUid, { publicLink: "remove" });
697
+ expect(sharingInfo).toEqual({
698
+ protonInvitations: [invitation],
699
+ nonProtonInvitations: [externalInvitation],
700
+ members: [member],
701
+ publicLink: undefined,
702
+ });
703
+ expect(apiService.deleteShare).not.toHaveBeenCalled();
704
+ expect(apiService.deleteInvitation).not.toHaveBeenCalled();
705
+ expect(apiService.deleteExternalInvitation).not.toHaveBeenCalled();
706
+ expect(apiService.removeMember).not.toHaveBeenCalled();
707
+ expect(apiService.removePublicLink).toHaveBeenCalled();
708
+ expect(nodesEvents.nodeUpdated).not.toHaveBeenCalled();
709
+ });
710
+ it("should remove share if all is removed", async () => {
711
+ const sharingInfo = await sharingManagement.unshareNode(nodeUid);
712
+ expect(sharingInfo).toEqual(undefined);
713
+ expect(apiService.deleteShare).toHaveBeenCalled();
714
+ expect(apiService.deleteInvitation).not.toHaveBeenCalled();
715
+ expect(apiService.deleteExternalInvitation).not.toHaveBeenCalled();
716
+ expect(apiService.removeMember).not.toHaveBeenCalled();
717
+ expect(apiService.removePublicLink).not.toHaveBeenCalled();
718
+ expect(nodesEvents.nodeUpdated).toHaveBeenCalledWith({
719
+ uid: nodeUid,
720
+ shareId: undefined,
721
+ isShared: false,
722
+ });
723
+ });
724
+ it("should remove share if everything is manually removed", async () => {
725
+ const sharingInfo = await sharingManagement.unshareNode(nodeUid, {
726
+ users: ["internal-email", "external-email", "member-email"],
727
+ publicLink: "remove",
728
+ });
729
+ expect(sharingInfo).toEqual(undefined);
730
+ expect(apiService.deleteShare).toHaveBeenCalled();
731
+ expect(apiService.deleteInvitation).toHaveBeenCalled();
732
+ expect(apiService.deleteExternalInvitation).toHaveBeenCalled();
733
+ expect(apiService.removeMember).toHaveBeenCalled();
734
+ expect(apiService.removePublicLink).toHaveBeenCalled();
735
+ expect(nodesEvents.nodeUpdated).toHaveBeenCalledWith({
736
+ uid: nodeUid,
737
+ shareId: undefined,
738
+ isShared: false,
739
+ });
740
+ });
741
+ });
742
+ describe("resendInvitationEmail", () => {
743
+ const nodeUid = "volumeId~nodeUid";
744
+ const invitation = {
745
+ uid: "invitation",
746
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
747
+ inviteeEmail: "internal-email",
748
+ role: interface_1.MemberRole.Viewer,
749
+ invitationTime: new Date(),
750
+ };
751
+ const externalInvitation = {
752
+ uid: "external-invitation",
753
+ addedByEmail: (0, interface_1.resultOk)("added-email"),
754
+ inviteeEmail: "external-email",
755
+ role: interface_1.MemberRole.Viewer,
756
+ invitationTime: new Date(),
757
+ state: interface_1.NonProtonInvitationState.Pending,
758
+ };
759
+ beforeEach(() => {
760
+ apiService.getShareInvitations = jest.fn().mockResolvedValue([invitation]);
761
+ apiService.getShareExternalInvitations = jest.fn().mockResolvedValue([externalInvitation]);
762
+ apiService.getShareMembers = jest.fn().mockResolvedValue([]);
763
+ apiService.getPublicLink = jest.fn().mockResolvedValue(undefined);
764
+ });
765
+ it("should resend email for proton invitation", async () => {
766
+ await sharingManagement.resendInvitationEmail(nodeUid, invitation.uid);
767
+ expect(apiService.resendInvitationEmail).toHaveBeenCalledWith(invitation.uid);
768
+ expect(apiService.resendExternalInvitationEmail).not.toHaveBeenCalled();
769
+ });
770
+ it("should resend email for external invitation", async () => {
771
+ await sharingManagement.resendInvitationEmail(nodeUid, externalInvitation.uid);
772
+ expect(apiService.resendExternalInvitationEmail).toHaveBeenCalledWith(externalInvitation.uid);
773
+ expect(apiService.resendInvitationEmail).not.toHaveBeenCalled();
774
+ });
775
+ it("should throw error when no sharing found for node", async () => {
776
+ nodesService.getNode = jest.fn().mockResolvedValue({ nodeUid, shareId: undefined });
777
+ await expect(sharingManagement.resendInvitationEmail(nodeUid, invitation.uid)).rejects.toThrow("Node is not shared");
778
+ expect(apiService.resendInvitationEmail).not.toHaveBeenCalled();
779
+ expect(apiService.resendExternalInvitationEmail).not.toHaveBeenCalled();
780
+ });
781
+ it("should log when no invitation found", async () => {
782
+ await expect(sharingManagement.resendInvitationEmail(nodeUid, "non-existent-uid")).rejects.toThrow("Invitation not found");
783
+ expect(apiService.resendInvitationEmail).not.toHaveBeenCalled();
784
+ expect(apiService.resendExternalInvitationEmail).not.toHaveBeenCalled();
785
+ });
786
+ });
787
+ });
788
+ //# sourceMappingURL=sharingManagement.test.js.map