@protontech/drive-sdk 0.0.13 → 0.1.1

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 (496) hide show
  1. package/dist/cache/index.d.ts +1 -0
  2. package/dist/cache/index.js +3 -1
  3. package/dist/cache/index.js.map +1 -1
  4. package/dist/cache/memoryCache.d.ts +1 -1
  5. package/dist/cache/memoryCache.js +0 -1
  6. package/dist/cache/memoryCache.js.map +1 -1
  7. package/dist/cache/memoryCache.test.js +2 -4
  8. package/dist/cache/memoryCache.test.js.map +1 -1
  9. package/dist/cache/nullCache.d.ts +14 -0
  10. package/dist/cache/nullCache.js +36 -0
  11. package/dist/cache/nullCache.js.map +1 -0
  12. package/dist/config.d.ts +16 -1
  13. package/dist/config.js +1 -1
  14. package/dist/config.js.map +1 -1
  15. package/dist/crypto/driveCrypto.d.ts +2 -5
  16. package/dist/crypto/driveCrypto.js +7 -12
  17. package/dist/crypto/driveCrypto.js.map +1 -1
  18. package/dist/crypto/driveCrypto.test.js +14 -14
  19. package/dist/crypto/openPGPCrypto.js +5 -3
  20. package/dist/crypto/openPGPCrypto.js.map +1 -1
  21. package/dist/diagnostic/eventsGenerator.d.ts +14 -0
  22. package/dist/diagnostic/eventsGenerator.js +49 -0
  23. package/dist/diagnostic/eventsGenerator.js.map +1 -0
  24. package/dist/diagnostic/httpClient.d.ts +16 -0
  25. package/dist/diagnostic/httpClient.js +81 -0
  26. package/dist/diagnostic/httpClient.js.map +1 -0
  27. package/dist/diagnostic/index.d.ts +10 -0
  28. package/dist/diagnostic/index.js +35 -0
  29. package/dist/diagnostic/index.js.map +1 -0
  30. package/dist/diagnostic/integrityVerificationStream.d.ts +21 -0
  31. package/dist/diagnostic/integrityVerificationStream.js +56 -0
  32. package/dist/diagnostic/integrityVerificationStream.js.map +1 -0
  33. package/dist/diagnostic/interface.d.ts +102 -0
  34. package/dist/diagnostic/interface.js +3 -0
  35. package/dist/diagnostic/interface.js.map +1 -0
  36. package/dist/diagnostic/sdkDiagnostic.d.ts +22 -0
  37. package/dist/diagnostic/sdkDiagnostic.js +222 -0
  38. package/dist/diagnostic/sdkDiagnostic.js.map +1 -0
  39. package/dist/diagnostic/sdkDiagnosticFull.d.ts +18 -0
  40. package/dist/diagnostic/sdkDiagnosticFull.js +35 -0
  41. package/dist/diagnostic/sdkDiagnosticFull.js.map +1 -0
  42. package/dist/diagnostic/telemetry.d.ts +25 -0
  43. package/dist/diagnostic/telemetry.js +70 -0
  44. package/dist/diagnostic/telemetry.js.map +1 -0
  45. package/dist/diagnostic/zipGenerators.d.ts +9 -0
  46. package/dist/diagnostic/zipGenerators.js +64 -0
  47. package/dist/diagnostic/zipGenerators.js.map +1 -0
  48. package/dist/diagnostic/zipGenerators.test.js +144 -0
  49. package/dist/diagnostic/zipGenerators.test.js.map +1 -0
  50. package/dist/errors.d.ts +2 -1
  51. package/dist/errors.js +3 -1
  52. package/dist/errors.js.map +1 -1
  53. package/dist/interface/config.d.ts +26 -0
  54. package/dist/interface/config.js +3 -0
  55. package/dist/interface/config.js.map +1 -0
  56. package/dist/interface/download.d.ts +2 -2
  57. package/dist/interface/events.d.ts +58 -20
  58. package/dist/interface/events.js +11 -1
  59. package/dist/interface/events.js.map +1 -1
  60. package/dist/interface/httpClient.d.ts +0 -14
  61. package/dist/interface/index.d.ts +11 -7
  62. package/dist/interface/index.js +2 -2
  63. package/dist/interface/index.js.map +1 -1
  64. package/dist/interface/nodes.d.ts +9 -0
  65. package/dist/interface/nodes.js.map +1 -1
  66. package/dist/interface/result.js.map +1 -1
  67. package/dist/interface/sharing.d.ts +2 -0
  68. package/dist/interface/sharing.js.map +1 -1
  69. package/dist/interface/telemetry.js +0 -8
  70. package/dist/interface/telemetry.js.map +1 -1
  71. package/dist/interface/thumbnail.js.map +1 -1
  72. package/dist/interface/upload.d.ts +7 -1
  73. package/dist/internal/apiService/apiService.d.ts +1 -1
  74. package/dist/internal/apiService/apiService.js +7 -11
  75. package/dist/internal/apiService/apiService.js.map +1 -1
  76. package/dist/internal/apiService/apiService.test.js +55 -48
  77. package/dist/internal/apiService/apiService.test.js.map +1 -1
  78. package/dist/internal/apiService/coreTypes.d.ts +2356 -2356
  79. package/dist/internal/apiService/driveTypes.d.ts +1680 -1680
  80. package/dist/internal/apiService/errors.js +14 -8
  81. package/dist/internal/apiService/errors.js.map +1 -1
  82. package/dist/internal/apiService/errors.test.js +17 -12
  83. package/dist/internal/apiService/errors.test.js.map +1 -1
  84. package/dist/internal/apiService/transformers.d.ts +1 -1
  85. package/dist/internal/apiService/transformers.js +1 -1
  86. package/dist/internal/asyncIteratorMap.test.js +2 -2
  87. package/dist/internal/asyncIteratorMap.test.js.map +1 -1
  88. package/dist/internal/asyncIteratorRace.d.ts +13 -0
  89. package/dist/internal/asyncIteratorRace.js +59 -0
  90. package/dist/internal/asyncIteratorRace.js.map +1 -0
  91. package/dist/internal/asyncIteratorRace.test.d.ts +1 -0
  92. package/dist/internal/asyncIteratorRace.test.js +119 -0
  93. package/dist/internal/asyncIteratorRace.test.js.map +1 -0
  94. package/dist/internal/batch.d.ts +1 -0
  95. package/dist/internal/batch.js +12 -0
  96. package/dist/internal/batch.js.map +1 -0
  97. package/dist/internal/batch.test.d.ts +1 -0
  98. package/dist/internal/batch.test.js +41 -0
  99. package/dist/internal/batch.test.js.map +1 -0
  100. package/dist/internal/batchLoading.js.map +1 -1
  101. package/dist/internal/batchLoading.test.js +13 -13
  102. package/dist/internal/batchLoading.test.js.map +1 -1
  103. package/dist/internal/devices/apiService.d.ts +3 -3
  104. package/dist/internal/devices/apiService.js +2 -2
  105. package/dist/internal/devices/apiService.js.map +1 -1
  106. package/dist/internal/devices/cryptoService.js +1 -2
  107. package/dist/internal/devices/cryptoService.js.map +1 -1
  108. package/dist/internal/devices/index.d.ts +5 -5
  109. package/dist/internal/devices/index.js.map +1 -1
  110. package/dist/internal/devices/interface.d.ts +3 -3
  111. package/dist/internal/devices/manager.js +2 -2
  112. package/dist/internal/devices/manager.js.map +1 -1
  113. package/dist/internal/devices/manager.test.js +38 -7
  114. package/dist/internal/devices/manager.test.js.map +1 -1
  115. package/dist/internal/download/apiService.d.ts +4 -4
  116. package/dist/internal/download/apiService.js +32 -32
  117. package/dist/internal/download/apiService.js.map +1 -1
  118. package/dist/internal/download/cryptoService.d.ts +4 -4
  119. package/dist/internal/download/cryptoService.js +6 -5
  120. package/dist/internal/download/cryptoService.js.map +1 -1
  121. package/dist/internal/download/fileDownloader.d.ts +6 -6
  122. package/dist/internal/download/fileDownloader.js +3 -2
  123. package/dist/internal/download/fileDownloader.js.map +1 -1
  124. package/dist/internal/download/fileDownloader.test.js +1 -1
  125. package/dist/internal/download/fileDownloader.test.js.map +1 -1
  126. package/dist/internal/download/index.d.ts +5 -5
  127. package/dist/internal/download/index.js +5 -5
  128. package/dist/internal/download/index.js.map +1 -1
  129. package/dist/internal/download/interface.d.ts +3 -4
  130. package/dist/internal/download/telemetry.d.ts +3 -3
  131. package/dist/internal/download/telemetry.js +4 -2
  132. package/dist/internal/download/telemetry.js.map +1 -1
  133. package/dist/internal/download/telemetry.test.js +8 -8
  134. package/dist/internal/download/telemetry.test.js.map +1 -1
  135. package/dist/internal/download/thumbnailDownloader.d.ts +4 -4
  136. package/dist/internal/download/thumbnailDownloader.js +6 -6
  137. package/dist/internal/download/thumbnailDownloader.js.map +1 -1
  138. package/dist/internal/download/thumbnailDownloader.test.js.map +1 -1
  139. package/dist/internal/errors.d.ts +1 -1
  140. package/dist/internal/errors.js +1 -3
  141. package/dist/internal/errors.js.map +1 -1
  142. package/dist/internal/events/apiService.d.ts +5 -7
  143. package/dist/internal/events/apiService.js +19 -22
  144. package/dist/internal/events/apiService.js.map +1 -1
  145. package/dist/internal/events/coreEventManager.d.ts +9 -12
  146. package/dist/internal/events/coreEventManager.js +19 -36
  147. package/dist/internal/events/coreEventManager.js.map +1 -1
  148. package/dist/internal/events/coreEventManager.test.d.ts +1 -0
  149. package/dist/internal/events/coreEventManager.test.js +87 -0
  150. package/dist/internal/events/coreEventManager.test.js.map +1 -0
  151. package/dist/internal/events/eventManager.d.ts +11 -36
  152. package/dist/internal/events/eventManager.js +59 -106
  153. package/dist/internal/events/eventManager.js.map +1 -1
  154. package/dist/internal/events/eventManager.test.js +177 -83
  155. package/dist/internal/events/eventManager.test.js.map +1 -1
  156. package/dist/internal/events/index.d.ts +16 -36
  157. package/dist/internal/events/index.js +56 -72
  158. package/dist/internal/events/index.js.map +1 -1
  159. package/dist/internal/events/interface.d.ts +59 -14
  160. package/dist/internal/events/interface.js +12 -3
  161. package/dist/internal/events/interface.js.map +1 -1
  162. package/dist/internal/events/volumeEventManager.d.ts +9 -19
  163. package/dist/internal/events/volumeEventManager.js +58 -45
  164. package/dist/internal/events/volumeEventManager.js.map +1 -1
  165. package/dist/internal/events/volumeEventManager.test.d.ts +1 -0
  166. package/dist/internal/events/volumeEventManager.test.js +203 -0
  167. package/dist/internal/events/volumeEventManager.test.js.map +1 -0
  168. package/dist/internal/nodes/apiService.d.ts +4 -3
  169. package/dist/internal/nodes/apiService.js +36 -15
  170. package/dist/internal/nodes/apiService.js.map +1 -1
  171. package/dist/internal/nodes/apiService.test.js +60 -41
  172. package/dist/internal/nodes/apiService.test.js.map +1 -1
  173. package/dist/internal/nodes/cache.d.ts +14 -5
  174. package/dist/internal/nodes/cache.js +31 -7
  175. package/dist/internal/nodes/cache.js.map +1 -1
  176. package/dist/internal/nodes/cache.test.js +31 -9
  177. package/dist/internal/nodes/cache.test.js.map +1 -1
  178. package/dist/internal/nodes/cryptoCache.d.ts +2 -2
  179. package/dist/internal/nodes/cryptoCache.js.map +1 -1
  180. package/dist/internal/nodes/cryptoCache.test.js +24 -4
  181. package/dist/internal/nodes/cryptoCache.test.js.map +1 -1
  182. package/dist/internal/nodes/cryptoService.d.ts +4 -4
  183. package/dist/internal/nodes/cryptoService.js +11 -17
  184. package/dist/internal/nodes/cryptoService.js.map +1 -1
  185. package/dist/internal/nodes/cryptoService.test.js +320 -241
  186. package/dist/internal/nodes/cryptoService.test.js.map +1 -1
  187. package/dist/internal/nodes/events.d.ts +8 -84
  188. package/dist/internal/nodes/events.js +43 -217
  189. package/dist/internal/nodes/events.js.map +1 -1
  190. package/dist/internal/nodes/events.test.js +35 -279
  191. package/dist/internal/nodes/events.test.js.map +1 -1
  192. package/dist/internal/nodes/extendedAttributes.d.ts +1 -1
  193. package/dist/internal/nodes/extendedAttributes.js +3 -1
  194. package/dist/internal/nodes/extendedAttributes.js.map +1 -1
  195. package/dist/internal/nodes/extendedAttributes.test.js +7 -10
  196. package/dist/internal/nodes/extendedAttributes.test.js.map +1 -1
  197. package/dist/internal/nodes/index.d.ts +12 -13
  198. package/dist/internal/nodes/index.js +5 -5
  199. package/dist/internal/nodes/index.js.map +1 -1
  200. package/dist/internal/nodes/index.test.js +24 -32
  201. package/dist/internal/nodes/index.test.js.map +1 -1
  202. package/dist/internal/nodes/interface.d.ts +2 -2
  203. package/dist/internal/nodes/nodesAccess.d.ts +22 -7
  204. package/dist/internal/nodes/nodesAccess.js +65 -16
  205. package/dist/internal/nodes/nodesAccess.js.map +1 -1
  206. package/dist/internal/nodes/nodesAccess.test.js +165 -101
  207. package/dist/internal/nodes/nodesAccess.test.js.map +1 -1
  208. package/dist/internal/nodes/nodesManagement.d.ts +7 -9
  209. package/dist/internal/nodes/nodesManagement.js +21 -33
  210. package/dist/internal/nodes/nodesManagement.js.map +1 -1
  211. package/dist/internal/nodes/nodesManagement.test.js +42 -21
  212. package/dist/internal/nodes/nodesManagement.test.js.map +1 -1
  213. package/dist/internal/nodes/nodesRevisions.d.ts +4 -4
  214. package/dist/internal/nodes/nodesRevisions.js.map +1 -1
  215. package/dist/internal/photos/albums.d.ts +3 -3
  216. package/dist/internal/photos/albums.js.map +1 -1
  217. package/dist/internal/photos/apiService.d.ts +1 -1
  218. package/dist/internal/photos/apiService.js +3 -6
  219. package/dist/internal/photos/apiService.js.map +1 -1
  220. package/dist/internal/photos/cache.d.ts +1 -1
  221. package/dist/internal/photos/index.d.ts +5 -5
  222. package/dist/internal/photos/index.js.map +1 -1
  223. package/dist/internal/photos/interface.d.ts +2 -2
  224. package/dist/internal/photos/photosTimeline.d.ts +3 -3
  225. package/dist/internal/photos/photosTimeline.js +1 -2
  226. package/dist/internal/photos/photosTimeline.js.map +1 -1
  227. package/dist/internal/sdkEvents.d.ts +1 -1
  228. package/dist/internal/sdkEvents.js +2 -7
  229. package/dist/internal/sdkEvents.js.map +1 -1
  230. package/dist/internal/sdkEvents.test.js +8 -8
  231. package/dist/internal/shares/apiService.d.ts +2 -2
  232. package/dist/internal/shares/apiService.js +5 -3
  233. package/dist/internal/shares/apiService.js.map +1 -1
  234. package/dist/internal/shares/cache.d.ts +4 -2
  235. package/dist/internal/shares/cache.js +14 -6
  236. package/dist/internal/shares/cache.js.map +1 -1
  237. package/dist/internal/shares/cache.test.js.map +1 -1
  238. package/dist/internal/shares/cryptoCache.d.ts +2 -2
  239. package/dist/internal/shares/cryptoCache.test.js +8 -2
  240. package/dist/internal/shares/cryptoCache.test.js.map +1 -1
  241. package/dist/internal/shares/cryptoService.d.ts +3 -3
  242. package/dist/internal/shares/cryptoService.js.map +1 -1
  243. package/dist/internal/shares/cryptoService.test.js +42 -42
  244. package/dist/internal/shares/cryptoService.test.js.map +1 -1
  245. package/dist/internal/shares/index.d.ts +4 -4
  246. package/dist/internal/shares/index.js.map +1 -1
  247. package/dist/internal/shares/interface.d.ts +2 -2
  248. package/dist/internal/shares/manager.d.ts +8 -7
  249. package/dist/internal/shares/manager.js +3 -0
  250. package/dist/internal/shares/manager.js.map +1 -1
  251. package/dist/internal/shares/manager.test.js +71 -63
  252. package/dist/internal/shares/manager.test.js.map +1 -1
  253. package/dist/internal/sharing/apiService.d.ts +4 -4
  254. package/dist/internal/sharing/apiService.js +5 -3
  255. package/dist/internal/sharing/apiService.js.map +1 -1
  256. package/dist/internal/sharing/cache.d.ts +1 -1
  257. package/dist/internal/sharing/cache.test.js +33 -33
  258. package/dist/internal/sharing/cryptoService.d.ts +3 -3
  259. package/dist/internal/sharing/cryptoService.js +3 -4
  260. package/dist/internal/sharing/cryptoService.js.map +1 -1
  261. package/dist/internal/sharing/cryptoService.test.js +39 -39
  262. package/dist/internal/sharing/cryptoService.test.js.map +1 -1
  263. package/dist/internal/sharing/events.d.ts +24 -56
  264. package/dist/internal/sharing/events.js +45 -138
  265. package/dist/internal/sharing/events.js.map +1 -1
  266. package/dist/internal/sharing/events.test.js +85 -189
  267. package/dist/internal/sharing/events.test.js.map +1 -1
  268. package/dist/internal/sharing/index.d.ts +8 -9
  269. package/dist/internal/sharing/index.js +5 -5
  270. package/dist/internal/sharing/index.js.map +1 -1
  271. package/dist/internal/sharing/interface.d.ts +8 -4
  272. package/dist/internal/sharing/sharingAccess.d.ts +6 -6
  273. package/dist/internal/sharing/sharingAccess.js +8 -4
  274. package/dist/internal/sharing/sharingAccess.js.map +1 -1
  275. package/dist/internal/sharing/sharingAccess.test.js +45 -39
  276. package/dist/internal/sharing/sharingAccess.test.js.map +1 -1
  277. package/dist/internal/sharing/sharingManagement.d.ts +5 -6
  278. package/dist/internal/sharing/sharingManagement.js +12 -16
  279. package/dist/internal/sharing/sharingManagement.js.map +1 -1
  280. package/dist/internal/sharing/sharingManagement.test.js +305 -286
  281. package/dist/internal/sharing/sharingManagement.test.js.map +1 -1
  282. package/dist/internal/uids.js.map +1 -1
  283. package/dist/internal/upload/apiService.d.ts +5 -6
  284. package/dist/internal/upload/apiService.js +8 -5
  285. package/dist/internal/upload/apiService.js.map +1 -1
  286. package/dist/internal/upload/blockVerifier.d.ts +3 -3
  287. package/dist/internal/upload/blockVerifier.js +1 -1
  288. package/dist/internal/upload/blockVerifier.js.map +1 -1
  289. package/dist/internal/upload/chunkStreamReader.test.js +6 -6
  290. package/dist/internal/upload/cryptoService.d.ts +4 -4
  291. package/dist/internal/upload/cryptoService.js +4 -4
  292. package/dist/internal/upload/cryptoService.js.map +1 -1
  293. package/dist/internal/upload/digests.js.map +1 -1
  294. package/dist/internal/upload/fileUploader.d.ts +6 -6
  295. package/dist/internal/upload/fileUploader.js.map +1 -1
  296. package/dist/internal/upload/fileUploader.test.js.map +1 -1
  297. package/dist/internal/upload/index.d.ts +6 -6
  298. package/dist/internal/upload/index.js +3 -3
  299. package/dist/internal/upload/index.js.map +1 -1
  300. package/dist/internal/upload/interface.d.ts +5 -3
  301. package/dist/internal/upload/manager.d.ts +8 -8
  302. package/dist/internal/upload/manager.js +23 -52
  303. package/dist/internal/upload/manager.js.map +1 -1
  304. package/dist/internal/upload/manager.test.js +185 -147
  305. package/dist/internal/upload/manager.test.js.map +1 -1
  306. package/dist/internal/upload/streamUploader.d.ts +6 -6
  307. package/dist/internal/upload/streamUploader.js +9 -8
  308. package/dist/internal/upload/streamUploader.js.map +1 -1
  309. package/dist/internal/upload/streamUploader.test.js +17 -12
  310. package/dist/internal/upload/streamUploader.test.js.map +1 -1
  311. package/dist/internal/upload/telemetry.d.ts +3 -3
  312. package/dist/internal/upload/telemetry.js +5 -3
  313. package/dist/internal/upload/telemetry.js.map +1 -1
  314. package/dist/internal/upload/telemetry.test.js +8 -8
  315. package/dist/internal/upload/telemetry.test.js.map +1 -1
  316. package/dist/protonDriveClient.d.ts +27 -170
  317. package/dist/protonDriveClient.js +37 -198
  318. package/dist/protonDriveClient.js.map +1 -1
  319. package/dist/protonDrivePhotosClient.js +3 -2
  320. package/dist/protonDrivePhotosClient.js.map +1 -1
  321. package/dist/telemetry.js +18 -15
  322. package/dist/telemetry.js.map +1 -1
  323. package/dist/tests/logger.js.map +1 -1
  324. package/dist/tests/telemetry.d.ts +1 -1
  325. package/dist/transformers.js +4 -2
  326. package/dist/transformers.js.map +1 -1
  327. package/package.json +3 -3
  328. package/src/cache/index.ts +1 -0
  329. package/src/cache/interface.ts +22 -22
  330. package/src/cache/memoryCache.test.ts +7 -7
  331. package/src/cache/memoryCache.ts +5 -5
  332. package/src/cache/nullCache.ts +38 -0
  333. package/src/config.ts +17 -2
  334. package/src/crypto/driveCrypto.test.ts +15 -15
  335. package/src/crypto/driveCrypto.ts +120 -156
  336. package/src/crypto/hmac.ts +1 -1
  337. package/src/crypto/interface.ts +63 -72
  338. package/src/crypto/openPGPCrypto.ts +76 -94
  339. package/src/crypto/utils.ts +1 -1
  340. package/src/diagnostic/eventsGenerator.ts +48 -0
  341. package/src/diagnostic/httpClient.ts +84 -0
  342. package/src/diagnostic/index.ts +40 -0
  343. package/src/diagnostic/integrityVerificationStream.ts +55 -0
  344. package/src/diagnostic/interface.ts +158 -0
  345. package/src/diagnostic/sdkDiagnostic.ts +249 -0
  346. package/src/diagnostic/sdkDiagnosticFull.ts +37 -0
  347. package/src/diagnostic/telemetry.ts +74 -0
  348. package/src/diagnostic/zipGenerators.test.ts +177 -0
  349. package/src/diagnostic/zipGenerators.ts +70 -0
  350. package/src/errors.ts +25 -22
  351. package/src/index.ts +3 -3
  352. package/src/interface/account.ts +10 -10
  353. package/src/interface/author.ts +6 -6
  354. package/src/interface/config.ts +28 -0
  355. package/src/interface/devices.ts +6 -6
  356. package/src/interface/download.ts +12 -9
  357. package/src/interface/events.ts +76 -25
  358. package/src/interface/httpClient.ts +11 -27
  359. package/src/interface/index.ts +81 -20
  360. package/src/interface/nodes.ts +67 -60
  361. package/src/interface/result.ts +1 -3
  362. package/src/interface/sharing.ts +60 -56
  363. package/src/interface/telemetry.ts +74 -74
  364. package/src/interface/thumbnail.ts +5 -6
  365. package/src/interface/upload.ts +25 -11
  366. package/src/internal/apiService/apiService.test.ts +109 -76
  367. package/src/internal/apiService/apiService.ts +40 -26
  368. package/src/internal/apiService/coreTypes.ts +2474 -2463
  369. package/src/internal/apiService/driveTypes.ts +1868 -1822
  370. package/src/internal/apiService/errorCodes.ts +4 -4
  371. package/src/internal/apiService/errors.test.ts +25 -23
  372. package/src/internal/apiService/errors.ts +15 -9
  373. package/src/internal/apiService/index.ts +1 -1
  374. package/src/internal/apiService/transformers.ts +2 -2
  375. package/src/internal/asyncIteratorMap.test.ts +4 -4
  376. package/src/internal/asyncIteratorMap.ts +1 -1
  377. package/src/internal/asyncIteratorRace.test.ts +149 -0
  378. package/src/internal/asyncIteratorRace.ts +79 -0
  379. package/src/internal/batch.test.ts +50 -0
  380. package/src/internal/batch.ts +9 -0
  381. package/src/internal/batchLoading.test.ts +13 -14
  382. package/src/internal/batchLoading.ts +8 -8
  383. package/src/internal/devices/apiService.ts +58 -51
  384. package/src/internal/devices/cryptoService.ts +22 -17
  385. package/src/internal/devices/index.ts +17 -10
  386. package/src/internal/devices/interface.ts +21 -12
  387. package/src/internal/devices/manager.test.ts +40 -9
  388. package/src/internal/devices/manager.ts +3 -3
  389. package/src/internal/download/apiService.ts +72 -52
  390. package/src/internal/download/cryptoService.ts +34 -18
  391. package/src/internal/download/fileDownloader.test.ts +25 -9
  392. package/src/internal/download/fileDownloader.ts +38 -20
  393. package/src/internal/download/index.ts +19 -19
  394. package/src/internal/download/interface.ts +19 -20
  395. package/src/internal/download/queue.ts +3 -3
  396. package/src/internal/download/telemetry.test.ts +11 -11
  397. package/src/internal/download/telemetry.ts +24 -14
  398. package/src/internal/download/thumbnailDownloader.test.ts +11 -6
  399. package/src/internal/download/thumbnailDownloader.ts +43 -32
  400. package/src/internal/errors.ts +7 -5
  401. package/src/internal/events/apiService.ts +46 -36
  402. package/src/internal/events/coreEventManager.test.ts +101 -0
  403. package/src/internal/events/coreEventManager.ts +26 -48
  404. package/src/internal/events/eventManager.test.ts +211 -93
  405. package/src/internal/events/eventManager.ts +72 -117
  406. package/src/internal/events/index.ts +71 -91
  407. package/src/internal/events/interface.ts +92 -29
  408. package/src/internal/events/volumeEventManager.test.ts +239 -0
  409. package/src/internal/events/volumeEventManager.ts +68 -57
  410. package/src/internal/nodes/apiService.test.ts +197 -147
  411. package/src/internal/nodes/apiService.ts +288 -174
  412. package/src/internal/nodes/cache.test.ts +48 -20
  413. package/src/internal/nodes/cache.ts +79 -45
  414. package/src/internal/nodes/cryptoCache.test.ts +34 -14
  415. package/src/internal/nodes/cryptoCache.ts +10 -5
  416. package/src/internal/nodes/cryptoService.test.ts +492 -351
  417. package/src/internal/nodes/cryptoService.ts +171 -89
  418. package/src/internal/nodes/events.test.ts +48 -344
  419. package/src/internal/nodes/events.ts +48 -254
  420. package/src/internal/nodes/extendedAttributes.test.ts +28 -24
  421. package/src/internal/nodes/extendedAttributes.ts +20 -15
  422. package/src/internal/nodes/index.test.ts +51 -55
  423. package/src/internal/nodes/index.ts +32 -22
  424. package/src/internal/nodes/interface.ts +44 -31
  425. package/src/internal/nodes/nodesAccess.test.ts +237 -130
  426. package/src/internal/nodes/nodesAccess.ts +113 -50
  427. package/src/internal/nodes/nodesManagement.test.ts +64 -39
  428. package/src/internal/nodes/nodesManagement.ts +51 -62
  429. package/src/internal/nodes/nodesRevisions.ts +7 -7
  430. package/src/internal/nodes/validations.ts +2 -2
  431. package/src/internal/photos/albums.ts +5 -5
  432. package/src/internal/photos/apiService.ts +4 -7
  433. package/src/internal/photos/cache.ts +1 -1
  434. package/src/internal/photos/index.ts +8 -8
  435. package/src/internal/photos/interface.ts +2 -2
  436. package/src/internal/photos/photosTimeline.ts +4 -5
  437. package/src/internal/sdkEvents.test.ts +10 -10
  438. package/src/internal/sdkEvents.ts +5 -13
  439. package/src/internal/shares/apiService.ts +44 -33
  440. package/src/internal/shares/cache.test.ts +6 -4
  441. package/src/internal/shares/cache.ts +25 -14
  442. package/src/internal/shares/cryptoCache.test.ts +17 -11
  443. package/src/internal/shares/cryptoCache.ts +4 -4
  444. package/src/internal/shares/cryptoService.test.ts +72 -74
  445. package/src/internal/shares/cryptoService.ts +48 -23
  446. package/src/internal/shares/index.ts +23 -11
  447. package/src/internal/shares/interface.ts +8 -8
  448. package/src/internal/shares/manager.test.ts +88 -80
  449. package/src/internal/shares/manager.ts +27 -23
  450. package/src/internal/sharing/apiService.ts +283 -175
  451. package/src/internal/sharing/cache.test.ts +35 -35
  452. package/src/internal/sharing/cache.ts +3 -3
  453. package/src/internal/sharing/cryptoService.test.ts +58 -46
  454. package/src/internal/sharing/cryptoService.ts +121 -83
  455. package/src/internal/sharing/events.test.ts +97 -207
  456. package/src/internal/sharing/events.ts +46 -157
  457. package/src/internal/sharing/index.ts +24 -16
  458. package/src/internal/sharing/interface.ts +46 -42
  459. package/src/internal/sharing/sharingAccess.test.ts +71 -65
  460. package/src/internal/sharing/sharingAccess.ts +39 -21
  461. package/src/internal/sharing/sharingManagement.test.ts +405 -335
  462. package/src/internal/sharing/sharingManagement.ts +144 -75
  463. package/src/internal/uids.ts +1 -1
  464. package/src/internal/upload/apiService.ts +168 -119
  465. package/src/internal/upload/blockVerifier.ts +8 -6
  466. package/src/internal/upload/chunkStreamReader.test.ts +7 -7
  467. package/src/internal/upload/cryptoService.ts +42 -36
  468. package/src/internal/upload/digests.ts +2 -2
  469. package/src/internal/upload/fileUploader.test.ts +15 -3
  470. package/src/internal/upload/fileUploader.ts +39 -17
  471. package/src/internal/upload/index.ts +17 -18
  472. package/src/internal/upload/interface.ts +79 -77
  473. package/src/internal/upload/manager.test.ts +222 -175
  474. package/src/internal/upload/manager.ts +74 -80
  475. package/src/internal/upload/queue.ts +3 -3
  476. package/src/internal/upload/streamUploader.test.ts +40 -27
  477. package/src/internal/upload/streamUploader.ts +87 -71
  478. package/src/internal/upload/telemetry.test.ts +11 -11
  479. package/src/internal/upload/telemetry.ts +25 -15
  480. package/src/internal/wait.test.ts +1 -1
  481. package/src/internal/wait.ts +3 -3
  482. package/src/protonDriveClient.ts +189 -276
  483. package/src/protonDrivePhotosClient.ts +20 -13
  484. package/src/telemetry.ts +60 -52
  485. package/src/tests/logger.ts +1 -1
  486. package/src/tests/telemetry.ts +2 -2
  487. package/src/transformers.ts +27 -21
  488. package/src/version.ts +0 -1
  489. package/dist/internal/events/cache.d.ts +0 -28
  490. package/dist/internal/events/cache.js +0 -67
  491. package/dist/internal/events/cache.js.map +0 -1
  492. package/dist/internal/events/cache.test.js +0 -43
  493. package/dist/internal/events/cache.test.js.map +0 -1
  494. package/src/internal/events/cache.test.ts +0 -47
  495. package/src/internal/events/cache.ts +0 -80
  496. /package/dist/{internal/events/cache.test.d.ts → diagnostic/zipGenerators.test.d.ts} +0 -0
@@ -1,13 +1,16 @@
1
- import { getMockLogger } from "../../tests/logger";
2
- import { DriveEvent, DriveEventType } from "../events";
3
- import { NodesService, SharingType } from "./interface";
4
- import { SharingCache } from "./cache";
5
- import { handleSharedByMeNodes, handleSharedWithMeNodes } from "./events";
6
- import { SharingAccess } from "./sharingAccess";
1
+ import { getMockLogger } from '../../tests/logger';
2
+ import { DriveEvent, DriveEventType } from '../events';
3
+ import { SharingCache } from './cache';
4
+ import { SharingAccess } from './sharingAccess';
5
+ import { SharingEventHandler } from './events';
6
+ import { SharesManager } from '../shares/manager';
7
7
 
8
- describe("handleSharedByMeNodes", () => {
8
+ // FIXME: test tree_refresh and tree_remove
9
+
10
+ describe('handleSharedByMeNodes', () => {
9
11
  let cache: SharingCache;
10
- let nodesService: NodesService;
12
+ let sharingEventHandler: SharingEventHandler;
13
+ let sharesManager: SharesManager;
11
14
 
12
15
  beforeEach(() => {
13
16
  jest.clearAllMocks();
@@ -17,204 +20,109 @@ describe("handleSharedByMeNodes", () => {
17
20
  addSharedByMeNodeUid: jest.fn(),
18
21
  removeSharedByMeNodeUid: jest.fn(),
19
22
  setSharedWithMeNodeUids: jest.fn(),
23
+ getSharedByMeNodeUids: jest.fn().mockResolvedValue(['cachedNodeUid']),
20
24
  };
21
- // @ts-expect-error No need to implement all methods for mocking
22
- nodesService = {
23
- getNode: jest.fn().mockResolvedValue({ uid: 'nodeUid', name: { ok: true, value: 'name' } }),
24
- };
25
+ sharesManager = {
26
+ isOwnVolume: jest.fn(async (volumeId: string) => volumeId === 'MyVolume1'),
27
+ } as any;
28
+ sharingEventHandler = new SharingEventHandler(getMockLogger(), cache, sharesManager);
25
29
  });
26
30
 
27
- const testCases: {
28
- title: string,
29
- existingNodeUids: string[],
30
- event: DriveEvent,
31
- added: boolean,
32
- removed: boolean,
33
- }[] = [
34
- {
35
- title: "should add if new own shared node is created",
36
- existingNodeUids: [],
37
- event: {
31
+ describe('node events trigger cache update', () => {
32
+ it('should add if new own shared node is created', async () => {
33
+ const event: DriveEvent = {
34
+ eventId: '1',
38
35
  type: DriveEventType.NodeCreated,
39
- nodeUid: "nodeUid",
40
- parentNodeUid: "parentUid",
36
+ nodeUid: 'newNodeUid',
37
+ parentNodeUid: 'parentUid',
41
38
  isTrashed: false,
42
39
  isShared: true,
43
- isOwnVolume: true,
44
- },
45
- added: true,
46
- removed: false,
47
- },
48
- {
49
- title: "should not add if new shared node is not own",
50
- existingNodeUids: [],
51
- event: {
40
+ treeEventScopeId: 'MyVolume1',
41
+ };
42
+ await sharingEventHandler.handleDriveEvent(event);
43
+ expect(cache.addSharedByMeNodeUid).toHaveBeenCalledWith('newNodeUid');
44
+ expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
45
+ });
46
+
47
+ test('should not add if new shared node is not own', async () => {
48
+ const event: DriveEvent = {
49
+ eventId: '1',
52
50
  type: DriveEventType.NodeCreated,
53
- nodeUid: "nodeUid",
54
- parentNodeUid: "parentUid",
51
+ nodeUid: 'newNodeUid',
52
+ parentNodeUid: 'parentUid',
55
53
  isTrashed: false,
56
54
  isShared: true,
57
- isOwnVolume: false,
58
- },
59
- added: false,
60
- removed: false,
61
- },
62
- {
63
- title: "should not add if new own node is not shared",
64
- existingNodeUids: [],
65
- event: {
55
+ treeEventScopeId: 'NotOwnVolume',
56
+ };
57
+ await sharingEventHandler.handleDriveEvent(event);
58
+ expect(cache.addSharedByMeNodeUid).not.toHaveBeenCalled();
59
+ expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
60
+ });
61
+
62
+ it('should not add if new own node is not shared', async () => {
63
+ const event: DriveEvent = {
66
64
  type: DriveEventType.NodeCreated,
67
- nodeUid: "nodeUid",
68
- parentNodeUid: "parentUid",
65
+ nodeUid: 'newNodeUid',
66
+ parentNodeUid: 'parentUid',
69
67
  isTrashed: false,
70
68
  isShared: false,
71
- isOwnVolume: true,
72
- },
73
- added: false,
74
- removed: false,
75
- },
76
- {
77
- title: "should add if own node is updated and shared",
78
- existingNodeUids: [],
79
- event: {
80
- type: DriveEventType.NodeUpdated,
81
- nodeUid: "nodeUid",
82
- parentNodeUid: "parentUid",
83
- isTrashed: false,
84
- isShared: true,
85
- isOwnVolume: true,
86
- },
87
- added: true,
88
- removed: false,
89
- },
90
- {
91
- title: "should add/update if shared node is updated",
92
- existingNodeUids: ["nodeUid"],
93
- event: {
69
+ eventId: '1',
70
+ treeEventScopeId: 'MyVolume1',
71
+ };
72
+ await sharingEventHandler.handleDriveEvent(event);
73
+ expect(cache.addSharedByMeNodeUid).not.toHaveBeenCalled();
74
+ expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
75
+ });
76
+
77
+ it('should add if own node is updated and shared', async () => {
78
+ const event: DriveEvent = {
94
79
  type: DriveEventType.NodeUpdated,
95
- nodeUid: "nodeUid",
96
- parentNodeUid: "parentUid",
80
+ nodeUid: 'cachedNodeUid',
81
+ parentNodeUid: 'parentUid',
97
82
  isTrashed: false,
98
83
  isShared: true,
99
- isOwnVolume: true,
100
- },
101
- added: true,
102
- removed: false,
103
- },
104
- {
105
- title: "should remove if shared node is un-shared",
106
- existingNodeUids: ["nodeUid"],
107
- event: {
108
- type: DriveEventType.NodeUpdated,
109
- nodeUid: "nodeUid",
110
- parentNodeUid: "parentUid",
111
- isTrashed: false,
112
- isShared: false,
113
- isOwnVolume: true,
114
- },
115
- added: false,
116
- removed: true,
117
- },
118
- {
119
- title: "should not remove if non-shared node is updated",
120
- existingNodeUids: [],
121
- event: {
84
+ eventId: '1',
85
+ treeEventScopeId: 'MyVolume1',
86
+ };
87
+ await sharingEventHandler.handleDriveEvent(event);
88
+ expect(cache.addSharedByMeNodeUid).toHaveBeenCalledWith('cachedNodeUid');
89
+ expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
90
+ });
91
+
92
+ it('should remove if shared node is un-shared', async () => {
93
+ const event: DriveEvent = {
122
94
  type: DriveEventType.NodeUpdated,
123
- nodeUid: "nodeUid",
124
- parentNodeUid: "parentUid",
95
+ nodeUid: 'cachedNodeUid',
96
+ parentNodeUid: 'parentUid',
125
97
  isTrashed: false,
126
98
  isShared: false,
127
- isOwnVolume: true,
128
- },
129
- added: false,
130
- removed: false,
131
- },
132
- {
133
- title: "should remove if shared node is deleted",
134
- existingNodeUids: ["nodeUid"],
135
- event: {
136
- type: DriveEventType.NodeDeleted,
137
- nodeUid: "nodeUid",
138
- parentNodeUid: "parentUid",
139
- isOwnVolume: true,
140
- },
141
- added: false,
142
- removed: true,
143
- },
144
- {
145
- title: "should not remove if non-shared node is deleted",
146
- existingNodeUids: [],
147
- event: {
148
- type: DriveEventType.NodeDeleted,
149
- nodeUid: "nodeUid",
150
- parentNodeUid: "parentUid",
151
- isOwnVolume: true,
152
- },
153
- added: false,
154
- removed: false,
155
- },
156
- ];
157
-
158
- describe("with listeners", () => {
159
- testCases.map(({ title, existingNodeUids, event, added, removed }) => {
160
- it(title, async () => {
161
- cache.getSharedByMeNodeUids = jest.fn().mockResolvedValue(existingNodeUids);
162
- const listener = jest.fn();
163
- const listeners = [{ type: SharingType.SharedByMe, callback: listener }];
164
-
165
- await handleSharedByMeNodes(getMockLogger(), event, cache, listeners, nodesService);
166
-
167
- if (added) {
168
- expect(cache.addSharedByMeNodeUid).toHaveBeenCalledWith("nodeUid");
169
- expect(listener).toHaveBeenCalledWith(expect.objectContaining({ type: 'update', uid: 'nodeUid' }));
170
- } else {
171
- expect(cache.addSharedByMeNodeUid).not.toHaveBeenCalled();
172
- }
173
- if (removed) {
174
- expect(cache.removeSharedByMeNodeUid).toHaveBeenCalledWith("nodeUid");
175
- expect(listener).toHaveBeenCalledWith({ type: 'remove', uid: 'nodeUid' });
176
- } else {
177
- expect(cache.removeSharedByMeNodeUid).not.toHaveBeenCalled();
178
- }
179
- if (!added && !removed) {
180
- expect(listener).not.toHaveBeenCalled();
181
- }
182
-
183
- expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
184
- });
99
+ eventId: '1',
100
+ treeEventScopeId: 'MyVolume1',
101
+ };
102
+ await sharingEventHandler.handleDriveEvent(event);
103
+ expect(cache.removeSharedByMeNodeUid).toHaveBeenCalledWith('cachedNodeUid');
104
+ expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
185
105
  });
186
- });
187
-
188
- describe("without listeners", () => {
189
- testCases.map(({ title, existingNodeUids, event, added, removed }) => {
190
- it(title, async () => {
191
- cache.getSharedByMeNodeUids = jest.fn().mockResolvedValue(existingNodeUids);
192
- const listener = jest.fn();
193
- const listeners = [{ type: SharingType.sharedWithMe, callback: listener }];
194
106
 
195
- await handleSharedByMeNodes(getMockLogger(), event, cache, listeners, nodesService);
196
-
197
- if (added) {
198
- expect(cache.addSharedByMeNodeUid).toHaveBeenCalledWith("nodeUid");
199
- } else {
200
- expect(cache.addSharedByMeNodeUid).not.toHaveBeenCalled();
201
- }
202
- if (removed) {
203
- expect(cache.removeSharedByMeNodeUid).toHaveBeenCalledWith("nodeUid");
204
- } else {
205
- expect(cache.removeSharedByMeNodeUid).not.toHaveBeenCalled();
206
- }
207
-
208
- expect(listener).not.toHaveBeenCalled();
209
- expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
210
- });
107
+ it('should remove if shared node is deleted', async () => {
108
+ const event: DriveEvent = {
109
+ type: DriveEventType.NodeDeleted,
110
+ nodeUid: 'cachedNodeUid',
111
+ parentNodeUid: 'parentUid',
112
+ eventId: '1',
113
+ treeEventScopeId: 'MyVolume1',
114
+ };
115
+ await sharingEventHandler.handleDriveEvent(event);
116
+ expect(cache.removeSharedByMeNodeUid).toHaveBeenCalledWith('cachedNodeUid');
117
+ expect(cache.setSharedWithMeNodeUids).not.toHaveBeenCalled();
211
118
  });
212
119
  });
213
120
  });
214
121
 
215
- describe("handleSharedWithMeNodes", () => {
122
+ describe('handleSharedWithMeNodes', () => {
216
123
  let cache: SharingCache;
217
124
  let sharingAccess: SharingAccess;
125
+ let sharesManager: SharesManager;
218
126
 
219
127
  beforeEach(() => {
220
128
  jest.clearAllMocks();
@@ -228,41 +136,23 @@ describe("handleSharedWithMeNodes", () => {
228
136
  sharingAccess = {
229
137
  iterateSharedNodesWithMe: jest.fn(),
230
138
  };
139
+ sharesManager = {
140
+ isOwnVolume: jest.fn(async (volumeId: string) => volumeId === 'MyVolume1'),
141
+ } as any;
231
142
  });
232
143
 
233
- it("should only update cache", async () => {
144
+ it('should only update cache', async () => {
234
145
  const event: DriveEvent = {
235
- type: DriveEventType.ShareWithMeUpdated,
146
+ type: DriveEventType.SharedWithMeUpdated,
147
+ eventId: 'event1',
148
+ treeEventScopeId: 'core',
236
149
  };
237
150
 
238
- await handleSharedWithMeNodes(event, cache, [], sharingAccess);
151
+ const sharingEventHandler = new SharingEventHandler(getMockLogger(), cache, sharesManager);
152
+ await sharingEventHandler.handleDriveEvent(event);
239
153
 
240
154
  expect(cache.setSharedWithMeNodeUids).toHaveBeenCalledWith(undefined);
241
155
  expect(cache.getSharedWithMeNodeUids).not.toHaveBeenCalled();
242
156
  expect(sharingAccess.iterateSharedNodesWithMe).not.toHaveBeenCalled();
243
157
  });
244
-
245
- it("should update cache and notify listener", async () => {
246
- cache.getSharedWithMeNodeUids = jest.fn().mockResolvedValue(["nodeUid1", "nodeUid4"]);
247
- sharingAccess.iterateSharedNodesWithMe = jest.fn().mockImplementation(async function* () {
248
- yield { uid: "nodeUid1", name: { ok: true, value: "name1" } };
249
- yield { uid: "nodeUid2", name: { ok: true, value: "name2" } };
250
- yield { uid: "nodeUid3", name: { ok: true, value: "name3" } };
251
- });
252
- const listener = jest.fn();
253
- const event: DriveEvent = {
254
- type: DriveEventType.ShareWithMeUpdated,
255
- };
256
-
257
- await handleSharedWithMeNodes(event, cache, [{ type: SharingType.sharedWithMe, callback: listener }], sharingAccess);
258
-
259
- expect(cache.setSharedWithMeNodeUids).toHaveBeenCalledWith(undefined);
260
- expect(cache.getSharedWithMeNodeUids).toHaveBeenCalled();
261
- expect(sharingAccess.iterateSharedNodesWithMe).toHaveBeenCalled();
262
- expect(listener).toHaveBeenCalledTimes(4);
263
- expect(listener).toHaveBeenCalledWith(expect.objectContaining({ type: 'update', uid: 'nodeUid1' }));
264
- expect(listener).toHaveBeenCalledWith(expect.objectContaining({ type: 'update', uid: 'nodeUid2' }));
265
- expect(listener).toHaveBeenCalledWith(expect.objectContaining({ type: 'update', uid: 'nodeUid3' }));
266
- expect(listener).toHaveBeenCalledWith({ type: 'remove', uid: 'nodeUid4' });
267
- });
268
158
  });
@@ -1,166 +1,55 @@
1
- import { NodeEventCallback, Logger } from "../../interface";
2
- import { convertInternalNode } from "../../transformers";
3
- import { DriveEventsService, DriveEvent, DriveEventType } from "../events";
4
- import { SharingCache } from "./cache";
5
- import { SharingType, NodesService } from "./interface";
6
- import { SharingAccess } from "./sharingAccess";
7
-
8
- type Listeners = {
9
- type: SharingType,
10
- callback: NodeEventCallback,
11
- }[];
12
-
13
- /**
14
- * Provides both event handling and subscription mechanism for user.
15
- *
16
- * The service is responsible for handling events regarding sharing listing
17
- * from the DriveEventsService, and for providing a subscription mechanism
18
- * for the user to listen to updates of specific group of nodes, such as
19
- * any update to list of shared with me nodes.
20
- */
21
- export class SharingEvents {
22
- private listeners: Listeners = [];
23
-
24
- constructor(logger: Logger, events: DriveEventsService, cache: SharingCache, nodesService: NodesService, sharingAccess: SharingAccess) {
25
- events.addListener(async (events, fullRefreshVolumeId) => {
26
- // Technically we need to refresh only the shared by me nodes for
27
- // own volume, and shared with me nodes only when the event comes
28
- // as core refresh event is converted to it.
29
- // We can optimise later, for now we refresh everything to make
30
- // it simpler. The cache is smart enough to not do unnecessary
31
- // requests to the API and refresh on web is rare without
32
- // persistant cache for now.
33
- if (fullRefreshVolumeId) {
34
- await cache.setSharedByMeNodeUids(undefined);
35
- await cache.setSharedWithMeNodeUids(undefined);
36
- return
1
+ import { Logger } from '../../interface';
2
+ import { DriveEvent, DriveEventType } from '../events';
3
+ import { SharingCache } from './cache';
4
+ import { SharesService } from './interface';
5
+
6
+ export class SharingEventHandler {
7
+ constructor(
8
+ private logger: Logger,
9
+ private cache: SharingCache,
10
+ private shares: SharesService,
11
+ ) {}
12
+
13
+ /**
14
+ * Update cache and notify listeners accordingly for any updates
15
+ * to nodes that are shared by me.
16
+ *
17
+ * Any node create or update that is being shared, is automatically
18
+ * added to the cache and the listeners are notified about the
19
+ * update of the node.
20
+ *
21
+ * Any node delete or update that is not being shared, and the cache
22
+ * includes the node, is removed from the cache and the listeners are
23
+ * notified about the removal of the node.
24
+ *
25
+ * @throws Only if the client's callback throws.
26
+ */
27
+ async handleDriveEvent(event: DriveEvent) {
28
+ try {
29
+ if (event.type === DriveEventType.SharedWithMeUpdated) {
30
+ await this.cache.setSharedWithMeNodeUids(undefined);
31
+ return;
37
32
  }
38
-
39
- for (const event of events) {
40
- await handleSharedByMeNodes(logger, event, cache, this.listeners, nodesService);
41
- await handleSharedWithMeNodes(event, cache, this.listeners, sharingAccess);
33
+ if (!(await this.shares.isOwnVolume(event.treeEventScopeId))) {
34
+ return;
42
35
  }
43
- });
44
- }
45
-
46
- subscribeToSharedNodesByMe(callback: NodeEventCallback) {
47
- this.listeners.push({ type: SharingType.SharedByMe, callback });
48
- return () => {
49
- this.listeners = this.listeners.filter(listener => listener.callback !== callback);
50
- }
51
- }
52
-
53
- subscribeToSharedNodesWithMe(callback: NodeEventCallback) {
54
- this.listeners.push({ type: SharingType.sharedWithMe, callback });
55
- return () => {
56
- this.listeners = this.listeners.filter(listener => listener.callback !== callback);
57
- }
58
- }
59
- }
60
-
61
- /**
62
- * Update cache and notify listeners accordingly for any updates
63
- * to nodes that are shared by me.
64
- *
65
- * Any node create or update that is being shared, is automatically
66
- * added to the cache and the listeners are notified about the
67
- * update of the node.
68
- *
69
- * Any node delete or update that is not being shared, and the cache
70
- * includes the node, is removed from the cache and the listeners are
71
- * notified about the removal of the node.
72
- *
73
- * @throws Only if the client's callback throws.
74
- */
75
- export async function handleSharedByMeNodes(logger: Logger, event: DriveEvent, cache: SharingCache, listeners: Listeners, nodesService: NodesService) {
76
- if (event.type === DriveEventType.ShareWithMeUpdated || !event.isOwnVolume) {
77
- return;
78
- }
79
-
80
- const subscribedListeners = listeners.filter(({ type }) => type === SharingType.SharedByMe);
81
-
82
- if ([DriveEventType.NodeCreated, DriveEventType.NodeUpdated, DriveEventType.NodeUpdatedMetadata].includes(event.type) && event.isShared) {
83
- try {
84
- await cache.addSharedByMeNodeUid(event.nodeUid);
85
- } catch (error: unknown) {
86
- logger.error(`Skipping shared by me node cache update`, error);
87
- }
88
- if (subscribedListeners.length) {
89
- let node;
90
- try {
91
- node = await nodesService.getNode(event.nodeUid);
92
- } catch (error: unknown) {
93
- logger.error(`Skipping shared by me node update event to listener`, error);
36
+ if (event.type === DriveEventType.NodeCreated || event.type == DriveEventType.NodeUpdated) {
37
+ if (event.isShared && !event.isTrashed) {
38
+ await this.cache.addSharedByMeNodeUid(event.nodeUid);
39
+ } else {
40
+ await this.cache.removeSharedByMeNodeUid(event.nodeUid);
41
+ }
94
42
  return;
95
43
  }
96
- subscribedListeners.forEach(({ callback }) => callback({ type: 'update', uid: node.uid, node: convertInternalNode(node) }));
97
- }
98
- }
99
-
100
- if (
101
- ((event.type === DriveEventType.NodeUpdated || event.type === DriveEventType.NodeUpdatedMetadata) && !event.isShared)
102
- || event.type === DriveEventType.NodeDeleted
103
- ) {
104
- let nodeWasShared = false;
105
- try {
106
- const cachedNodeUids = await cache.getSharedByMeNodeUids();
107
- nodeWasShared = cachedNodeUids.includes(event.nodeUid);
108
- } catch {
109
- // Cache can be empty.
110
- }
111
-
112
- if (nodeWasShared) {
113
- try {
114
- await cache.removeSharedByMeNodeUid(event.nodeUid);
115
- } catch (error: unknown) {
116
- logger.error(`Skipping shared by me node cache remove`, error);
44
+ if (event.type === DriveEventType.NodeDeleted) {
45
+ await this.cache.removeSharedByMeNodeUid(event.nodeUid);
46
+ return;
117
47
  }
118
- subscribedListeners.forEach(({ callback }) => callback({ type: 'remove', uid: event.nodeUid }));
119
- }
120
- }
121
- }
122
-
123
- /**
124
- * Update cache and notify listeners accordingly for any updates
125
- * to nodes that are shared with me.
126
- *
127
- * There is only one event type that is relevant for shared with me
128
- * nodes, which is the ShareWithMeUpdated event. The event is triggered
129
- * when the list of shared with me nodes is updated.
130
- *
131
- * The cache is cleared and re-populated fully when the client
132
- * requests the list of shared with me, or is actively listening.
133
- *
134
- * If the client listenes to shared with me updates, the client receives
135
- * update to the full list of shared with me nodes, including remove
136
- * updates for nodes that are no longer shared with me, but was before.
137
- *
138
- * @throws Only if the client's callback throws.
139
- */
140
- export async function handleSharedWithMeNodes(event: DriveEvent, cache: SharingCache, listeners: Listeners, sharingAccess: SharingAccess) {
141
- if (event.type !== DriveEventType.ShareWithMeUpdated) {
142
- return;
143
- }
144
-
145
- let cachedNodeUids: string[] = [];
146
- const subscribedListeners = listeners.filter(({ type }) => type === SharingType.sharedWithMe);
147
- if (subscribedListeners.length) {
148
- cachedNodeUids = await cache.getSharedWithMeNodeUids();
149
- }
150
-
151
- // Clearing the cache must be first, sharingAccess is no-op if cache is set.
152
- await cache.setSharedWithMeNodeUids(undefined);
153
-
154
- if (subscribedListeners.length) {
155
- const nodeUids = [];
156
- for await (const node of sharingAccess.iterateSharedNodesWithMe()) {
157
- nodeUids.push(node.uid);
158
- subscribedListeners.forEach(({ callback }) => callback({ type: 'update', uid: node.uid, node: convertInternalNode(node) }));
159
- }
160
- for (const nodeUid of cachedNodeUids) {
161
- if (!nodeUids.includes(nodeUid)) {
162
- subscribedListeners.forEach(({ callback }) => callback({ type: 'remove', uid: nodeUid }));
48
+ if (event.type === DriveEventType.TreeRefresh || event.type === DriveEventType.TreeRemove) {
49
+ await this.cache.setSharedWithMeNodeUids(undefined);
163
50
  }
51
+ } catch (error: unknown) {
52
+ this.logger.error(`Skipping shared by me node cache update`, error);
164
53
  }
165
54
  }
166
55
  }
@@ -1,18 +1,17 @@
1
- import { ProtonDriveAccount, ProtonDriveEntitiesCache, ProtonDriveTelemetry } from "../../interface";
1
+ import { ProtonDriveAccount, ProtonDriveEntitiesCache, ProtonDriveTelemetry } from '../../interface';
2
2
  import { DriveCrypto } from '../../crypto';
3
- import { DriveAPIService } from "../apiService";
4
- import { DriveEventsService } from "../events";
5
- import { SharingAPIService } from "./apiService";
6
- import { SharingCache } from "./cache";
7
- import { SharingCryptoService } from "./cryptoService";
8
- import { SharingEvents } from "./events";
9
- import { SharingAccess } from "./sharingAccess";
10
- import { SharingManagement } from "./sharingManagement";
11
- import { SharesService, NodesService, NodesEvents } from "./interface";
3
+ import { DriveAPIService } from '../apiService';
4
+ import { SharingAPIService } from './apiService';
5
+ import { SharingCache } from './cache';
6
+ import { SharingCryptoService } from './cryptoService';
7
+ import { SharingAccess } from './sharingAccess';
8
+ import { SharingManagement } from './sharingManagement';
9
+ import { SharesService, NodesService } from './interface';
10
+ import { SharingEventHandler } from './events';
12
11
 
13
12
  /**
14
13
  * Provides facade for the whole sharing module.
15
- *
14
+ *
16
15
  * The sharing module is responsible for handling invitations, bookmarks,
17
16
  * standard shares, listing shared nodes, etc. It includes API communication,
18
17
  * encryption, decryption, caching, and event handling.
@@ -23,21 +22,30 @@ export function initSharingModule(
23
22
  driveEntitiesCache: ProtonDriveEntitiesCache,
24
23
  account: ProtonDriveAccount,
25
24
  crypto: DriveCrypto,
26
- driveEvents: DriveEventsService,
27
25
  sharesService: SharesService,
28
26
  nodesService: NodesService,
29
- nodesEvents: NodesEvents,
30
27
  ) {
31
28
  const api = new SharingAPIService(telemetry.getLogger('sharing-api'), apiService);
32
29
  const cache = new SharingCache(driveEntitiesCache);
33
30
  const cryptoService = new SharingCryptoService(telemetry, crypto, account, sharesService);
34
31
  const sharingAccess = new SharingAccess(api, cache, cryptoService, sharesService, nodesService);
35
- const sharingEvents = new SharingEvents(telemetry.getLogger('sharing-events'), driveEvents, cache, nodesService, sharingAccess);
36
- const sharingManagement = new SharingManagement(telemetry.getLogger('sharing'), api, cryptoService, account, sharesService, nodesService, nodesEvents);
32
+ const sharingManagement = new SharingManagement(
33
+ telemetry.getLogger('sharing'),
34
+ api,
35
+ cryptoService,
36
+ account,
37
+ sharesService,
38
+ nodesService,
39
+ );
40
+ const sharingEventHandler = new SharingEventHandler(
41
+ telemetry.getLogger('sharing-event-handler'),
42
+ cache,
43
+ sharesService,
44
+ );
37
45
 
38
46
  return {
39
47
  access: sharingAccess,
40
- events: sharingEvents,
48
+ eventHandler: sharingEventHandler,
41
49
  management: sharingManagement,
42
50
  };
43
51
  }