@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,36 +1,37 @@
1
- import { ValidationError } from "../../errors";
2
- import { NodeType, ProtonDriveTelemetry, RevisionState, UploadMetadata } from "../../interface";
3
- import { getMockTelemetry } from "../../tests/telemetry";
4
- import { ErrorCode } from "../apiService";
5
- import { UploadAPIService } from "./apiService";
6
- import { UploadCryptoService } from "./cryptoService";
7
- import { NodesService, NodesEvents } from "./interface";
1
+ import { ValidationError } from '../../errors';
2
+ import { ProtonDriveTelemetry, UploadMetadata } from '../../interface';
3
+ import { getMockTelemetry } from '../../tests/telemetry';
4
+ import { ErrorCode } from '../apiService';
5
+ import { UploadAPIService } from './apiService';
6
+ import { UploadCryptoService } from './cryptoService';
7
+ import { NodesService } from './interface';
8
8
  import { UploadManager } from './manager';
9
9
 
10
- describe("UploadManager", () => {
10
+ describe('UploadManager', () => {
11
11
  let telemetry: ProtonDriveTelemetry;
12
12
  let apiService: UploadAPIService;
13
13
  let cryptoService: UploadCryptoService;
14
14
  let nodesService: NodesService;
15
- let nodesEvents: NodesEvents;
16
15
 
17
16
  let manager: UploadManager;
18
17
 
18
+ const clientUid = 'clientUid';
19
+
19
20
  beforeEach(() => {
20
21
  telemetry = getMockTelemetry();
21
22
  // @ts-expect-error No need to implement all methods for mocking
22
23
  apiService = {
23
24
  createDraft: jest.fn().mockResolvedValue({
24
- nodeUid: "newNode:nodeUid",
25
- nodeRevisionUid: "newNode:nodeRevisionUid",
25
+ nodeUid: 'newNode:nodeUid',
26
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
26
27
  }),
27
28
  deleteDraft: jest.fn(),
28
29
  checkAvailableHashes: jest.fn().mockResolvedValue({
29
- availalbleHashes: ["name1Hash"],
30
+ availalbleHashes: ['name1Hash'],
30
31
  pendingHashes: [],
31
32
  }),
32
33
  commitDraftRevision: jest.fn(),
33
- }
34
+ };
34
35
  // @ts-expect-error No need to implement all methods for mocking
35
36
  cryptoService = {
36
37
  generateFileCrypto: jest.fn().mockResolvedValue({
@@ -50,181 +51,250 @@ describe("UploadManager", () => {
50
51
  },
51
52
  },
52
53
  encryptedNode: {
53
- encryptedName: "newNode:encryptedName",
54
- hash: "newNode:hash",
54
+ encryptedName: 'newNode:encryptedName',
55
+ hash: 'newNode:hash',
55
56
  },
56
57
  signatureAddress: {
57
- email: "signatureEmail",
58
+ email: 'signatureEmail',
58
59
  },
59
60
  }),
60
- generateNameHashes: jest.fn().mockResolvedValue([{
61
- name: "name1",
62
- hash: "name1Hash",
63
- }, {
64
- name: "name2",
65
- hash: "name2Hash",
66
- }, {
67
- name: "name3",
68
- hash: "name3Hash",
69
- }]),
61
+ generateNameHashes: jest.fn().mockResolvedValue([
62
+ {
63
+ name: 'name1',
64
+ hash: 'name1Hash',
65
+ },
66
+ {
67
+ name: 'name2',
68
+ hash: 'name2Hash',
69
+ },
70
+ {
71
+ name: 'name3',
72
+ hash: 'name3Hash',
73
+ },
74
+ ]),
70
75
  commitFile: jest.fn().mockResolvedValue({
71
- armoredManifestSignature: "newNode:armoredManifestSignature",
72
- signatureEmail: "signatureEmail",
73
- armoredExtendedAttributes: "newNode:armoredExtendedAttributes",
76
+ armoredManifestSignature: 'newNode:armoredManifestSignature',
77
+ signatureEmail: 'signatureEmail',
78
+ armoredExtendedAttributes: 'newNode:armoredExtendedAttributes',
74
79
  }),
75
- }
76
- // @ts-expect-error No need to implement all methods for mocking
80
+ };
77
81
  nodesService = {
82
+ getNode: jest.fn(async (nodeUid: string) => ({
83
+ uid: nodeUid,
84
+ parentUid: 'parentUid',
85
+ })),
78
86
  getNodeKeys: jest.fn().mockResolvedValue({
79
87
  hashKey: 'parentNode:hashKey',
80
88
  key: 'parentNode:nodekey',
81
89
  }),
82
90
  getRootNodeEmailKey: jest.fn().mockResolvedValue({
83
- email: "signatureEmail",
84
- addressId: "addressId",
91
+ email: 'signatureEmail',
92
+ addressId: 'addressId',
93
+ }),
94
+ notifyChildCreated: jest.fn(async (nodeUid: string) => {
95
+ return;
85
96
  }),
86
- }
87
- nodesEvents = {
88
- nodeCreated: jest.fn(),
89
- nodeUpdated: jest.fn(),
90
- }
97
+ };
91
98
 
92
- manager = new UploadManager(telemetry, apiService, cryptoService, nodesService, nodesEvents);
99
+ manager = new UploadManager(telemetry, apiService, cryptoService, nodesService, clientUid);
93
100
  });
94
101
 
95
- describe("createDraftNode", () => {
96
- it("should fail to create node in non-folder parent", async () => {
102
+ describe('createDraftNode', () => {
103
+ it('should fail to create node in non-folder parent', async () => {
97
104
  nodesService.getNodeKeys = jest.fn().mockResolvedValue({ hashKey: undefined });
98
105
 
99
- const result = manager.createDraftNode("parentUid", "name", {} as UploadMetadata);
100
- await expect(result).rejects.toThrow("Creating files in non-folders is not allowed");
106
+ const result = manager.createDraftNode('parentUid', 'name', {} as UploadMetadata);
107
+ await expect(result).rejects.toThrow('Creating files in non-folders is not allowed');
101
108
  });
102
109
 
103
- it("should create draft node", async () => {
104
- const result = await manager.createDraftNode("parentUid", "name", {
105
- mediaType: "myMimeType",
110
+ it('should create draft node', async () => {
111
+ const result = await manager.createDraftNode('parentUid', 'name', {
112
+ mediaType: 'myMimeType',
106
113
  expectedSize: 123456,
107
114
  } as UploadMetadata);
108
115
 
109
116
  expect(result).toEqual({
110
- nodeUid: "newNode:nodeUid",
111
- nodeRevisionUid: "newNode:nodeRevisionUid",
117
+ nodeUid: 'newNode:nodeUid',
118
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
112
119
  nodeKeys: {
113
- key: "newNode:key",
114
- contentKeyPacketSessionKey: "newNode:ContentKeyPacketSessionKey",
120
+ key: 'newNode:key',
121
+ contentKeyPacketSessionKey: 'newNode:ContentKeyPacketSessionKey',
115
122
  signatureAddress: {
116
- email: "signatureEmail",
123
+ email: 'signatureEmail',
117
124
  },
118
125
  },
119
126
  newNodeInfo: {
120
- parentUid: "parentUid",
121
- name: "name",
122
- encryptedName: "newNode:encryptedName",
123
- hash: "newNode:hash",
127
+ parentUid: 'parentUid',
128
+ name: 'name',
129
+ encryptedName: 'newNode:encryptedName',
130
+ hash: 'newNode:hash',
124
131
  },
125
132
  });
126
- expect(apiService.createDraft).toHaveBeenCalledWith("parentUid", {
127
- armoredEncryptedName: "newNode:encryptedName",
128
- hash: "newNode:hash",
129
- mediaType: "myMimeType",
133
+ expect(apiService.createDraft).toHaveBeenCalledWith('parentUid', {
134
+ armoredEncryptedName: 'newNode:encryptedName',
135
+ hash: 'newNode:hash',
136
+ mediaType: 'myMimeType',
130
137
  intendedUploadSize: 123456,
131
- armoredNodeKey: "newNode:armoredKey",
132
- armoredNodePassphrase: "newNode:armoredPassphrase",
133
- armoredNodePassphraseSignature: "newNode:armoredPassphraseSignature",
134
- base64ContentKeyPacket: "newNode:base64ContentKeyPacket",
135
- armoredContentKeyPacketSignature: "newNode:armoredContentKeyPacketSignature",
136
- signatureEmail: "signatureEmail",
138
+ armoredNodeKey: 'newNode:armoredKey',
139
+ armoredNodePassphrase: 'newNode:armoredPassphrase',
140
+ armoredNodePassphraseSignature: 'newNode:armoredPassphraseSignature',
141
+ base64ContentKeyPacket: 'newNode:base64ContentKeyPacket',
142
+ armoredContentKeyPacketSignature: 'newNode:armoredContentKeyPacketSignature',
143
+ signatureEmail: 'signatureEmail',
137
144
  });
138
145
  });
139
146
 
140
- it("should delete existing draft and trying again", async () => {
147
+ it('should delete existing draft and trying again', async () => {
141
148
  let firstCall = true;
142
149
  apiService.createDraft = jest.fn().mockImplementation(() => {
143
150
  if (firstCall) {
144
151
  firstCall = false;
145
- throw new ValidationError("Draft already exists", ErrorCode.ALREADY_EXISTS, {
146
- ConflictLinkID: "existingLinkId",
147
- ConflictDraftRevisionID: "existingDraftRevisionId",
148
- ConflictDraftClientUID: "existingDraftClientUid",
152
+ throw new ValidationError('Draft already exists', ErrorCode.ALREADY_EXISTS, {
153
+ ConflictLinkID: 'existingLinkId',
154
+ ConflictDraftRevisionID: 'existingDraftRevisionId',
155
+ ConflictDraftClientUID: clientUid,
149
156
  });
150
157
  }
151
158
  return {
152
- nodeUid: "newNode:nodeUid",
153
- nodeRevisionUid: "newNode:nodeRevisionUid",
159
+ nodeUid: 'newNode:nodeUid',
160
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
154
161
  };
155
162
  });
156
163
 
157
- const result = await manager.createDraftNode("volumeId~parentUid", "name", {} as UploadMetadata);
164
+ const result = await manager.createDraftNode('volumeId~parentUid', 'name', {} as UploadMetadata);
158
165
 
159
- expect(apiService.deleteDraft).toHaveBeenCalledTimes(1);
160
166
  expect(result).toEqual({
161
- nodeUid: "newNode:nodeUid",
162
- nodeRevisionUid: "newNode:nodeRevisionUid",
167
+ nodeUid: 'newNode:nodeUid',
168
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
163
169
  nodeKeys: {
164
- key: "newNode:key",
165
- contentKeyPacketSessionKey: "newNode:ContentKeyPacketSessionKey",
170
+ key: 'newNode:key',
171
+ contentKeyPacketSessionKey: 'newNode:ContentKeyPacketSessionKey',
166
172
  signatureAddress: {
167
- email: "signatureEmail",
173
+ email: 'signatureEmail',
168
174
  },
169
175
  },
170
176
  newNodeInfo: {
171
- parentUid: "volumeId~parentUid",
172
- name: "name",
173
- encryptedName: "newNode:encryptedName",
174
- hash: "newNode:hash",
177
+ parentUid: 'volumeId~parentUid',
178
+ name: 'name',
179
+ encryptedName: 'newNode:encryptedName',
180
+ hash: 'newNode:hash',
175
181
  },
176
182
  });
177
- expect(apiService.deleteDraft).toHaveBeenCalledWith("volumeId~existingLinkId");
183
+ expect(apiService.deleteDraft).toHaveBeenCalledTimes(1);
184
+ expect(apiService.deleteDraft).toHaveBeenCalledWith('volumeId~existingLinkId');
185
+ });
186
+
187
+ it('should not delete existing draft if client UID does not match', async () => {
188
+ let firstCall = true;
189
+ apiService.createDraft = jest.fn().mockImplementation(() => {
190
+ if (firstCall) {
191
+ firstCall = false;
192
+ throw new ValidationError('Draft already exists', ErrorCode.ALREADY_EXISTS, {
193
+ ConflictLinkID: 'existingLinkId',
194
+ ConflictDraftRevisionID: 'existingDraftRevisionId',
195
+ ConflictDraftClientUID: 'anotherClientUid',
196
+ });
197
+ }
198
+ return {
199
+ nodeUid: 'newNode:nodeUid',
200
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
201
+ };
202
+ });
203
+
204
+ const promise = manager.createDraftNode('volumeId~parentUid', 'name', {} as UploadMetadata);
205
+
206
+ try {
207
+ await promise;
208
+ } catch (error: any) {
209
+ expect(error.message).toBe('Draft already exists');
210
+ expect(error.ongoingUploadByOtherClient).toBe(true);
211
+ }
212
+ expect(apiService.deleteDraft).not.toHaveBeenCalled();
213
+ });
214
+
215
+ it('should not delete existing draft if client UID is not set', async () => {
216
+ const clientUid = undefined;
217
+ manager = new UploadManager(telemetry, apiService, cryptoService, nodesService, clientUid);
218
+
219
+ let firstCall = true;
220
+ apiService.createDraft = jest.fn().mockImplementation(() => {
221
+ if (firstCall) {
222
+ firstCall = false;
223
+ throw new ValidationError('Draft already exists', ErrorCode.ALREADY_EXISTS, {
224
+ ConflictLinkID: 'existingLinkId',
225
+ ConflictDraftRevisionID: 'existingDraftRevisionId',
226
+ ConflictDraftClientUID: clientUid,
227
+ });
228
+ }
229
+ return {
230
+ nodeUid: 'newNode:nodeUid',
231
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
232
+ };
233
+ });
234
+
235
+ const promise = manager.createDraftNode('volumeId~parentUid', 'name', {} as UploadMetadata);
236
+
237
+ try {
238
+ await promise;
239
+ } catch (error: any) {
240
+ expect(error.message).toBe('Draft already exists');
241
+ expect(error.ongoingUploadByOtherClient).toBe(true);
242
+ }
243
+ expect(apiService.deleteDraft).not.toHaveBeenCalled();
178
244
  });
179
245
 
180
- it("should handle error when deleting existing draft", async () => {
246
+ it('should handle error when deleting existing draft', async () => {
181
247
  let firstCall = true;
182
248
  apiService.createDraft = jest.fn().mockImplementation(() => {
183
249
  if (firstCall) {
184
250
  firstCall = false;
185
- throw new ValidationError("Draft already exists", ErrorCode.ALREADY_EXISTS, {
186
- ConflictLinkID: "existingLinkId",
187
- ConflictDraftRevisionID: "existingDraftRevisionId",
188
- ConflictDraftClientUID: "existingDraftClientUid",
251
+ throw new ValidationError('Draft already exists', ErrorCode.ALREADY_EXISTS, {
252
+ ConflictLinkID: 'existingLinkId',
253
+ ConflictDraftRevisionID: 'existingDraftRevisionId',
254
+ ConflictDraftClientUID: clientUid,
189
255
  });
190
256
  }
191
257
  return {
192
- nodeUid: "newNode:nodeUid",
193
- nodeRevisionUid: "newNode:nodeRevisionUid",
258
+ nodeUid: 'newNode:nodeUid',
259
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
194
260
  };
195
261
  });
196
262
  apiService.deleteDraft = jest.fn().mockImplementation(() => {
197
- throw new Error("Failed to delete draft");
263
+ throw new Error('Failed to delete draft');
198
264
  });
199
265
 
200
- const result = manager.createDraftNode("volumeId~parentUid", "name", {} as UploadMetadata);
266
+ const result = manager.createDraftNode('volumeId~parentUid', 'name', {} as UploadMetadata);
201
267
 
202
268
  try {
203
269
  await result;
204
270
  } catch (error: any) {
205
- expect(error.message).toBe("Draft already exists");
206
- expect(error.existingNodeUid).toBe("volumeId~existingLinkId");
271
+ expect(error.message).toBe('Draft already exists');
272
+ expect(error.existingNodeUid).toBe('volumeId~existingLinkId');
207
273
  }
208
274
  expect(apiService.deleteDraft).toHaveBeenCalledTimes(1);
209
275
  });
210
276
  });
211
277
 
212
- describe("findAvailableName", () => {
213
- it("should find available name", async () => {
278
+ describe('findAvailableName', () => {
279
+ it('should find available name', async () => {
214
280
  apiService.checkAvailableHashes = jest.fn().mockImplementation(() => {
215
281
  return {
216
- availalbleHashes: ["name3Hash"],
282
+ availalbleHashes: ['name3Hash'],
217
283
  pendingHashes: [],
218
- }
284
+ };
219
285
  });
220
286
 
221
- const result = await manager.findAvailableName("parentUid", "name");
222
- expect(result).toBe("name3");
287
+ const result = await manager.findAvailableName('parentUid', 'name');
288
+ expect(result).toBe('name3');
223
289
  expect(apiService.checkAvailableHashes).toHaveBeenCalledTimes(1);
224
- expect(apiService.checkAvailableHashes).toHaveBeenCalledWith("parentUid", ["name1Hash", "name2Hash", "name3Hash"]);
290
+ expect(apiService.checkAvailableHashes).toHaveBeenCalledWith('parentUid', [
291
+ 'name1Hash',
292
+ 'name2Hash',
293
+ 'name3Hash',
294
+ ]);
225
295
  });
226
296
 
227
- it("should find available name with multiple pages", async () => {
297
+ it('should find available name with multiple pages', async () => {
228
298
  let firstCall = false;
229
299
  apiService.checkAvailableHashes = jest.fn().mockImplementation(() => {
230
300
  if (!firstCall) {
@@ -233,111 +303,88 @@ describe("UploadManager", () => {
233
303
  // First page has no available hashes
234
304
  availalbleHashes: [],
235
305
  pendingHashes: [],
236
- }
306
+ };
237
307
  }
238
308
  return {
239
- availalbleHashes: ["name3Hash"],
309
+ availalbleHashes: ['name3Hash'],
240
310
  pendingHashes: [],
241
- }
311
+ };
242
312
  });
243
313
 
244
- const result = await manager.findAvailableName("parentUid", "name");
245
- expect(result).toBe("name3");
314
+ const result = await manager.findAvailableName('parentUid', 'name');
315
+ expect(result).toBe('name3');
246
316
  expect(apiService.checkAvailableHashes).toHaveBeenCalledTimes(2);
247
- expect(apiService.checkAvailableHashes).toHaveBeenCalledWith("parentUid", ["name1Hash", "name2Hash", "name3Hash"]);
317
+ expect(apiService.checkAvailableHashes).toHaveBeenCalledWith('parentUid', [
318
+ 'name1Hash',
319
+ 'name2Hash',
320
+ 'name3Hash',
321
+ ]);
248
322
  });
249
323
  });
250
324
 
251
- describe("commit draft", () => {
325
+ describe('commit draft', () => {
252
326
  const nodeRevisionDraft = {
253
- nodeUid: "newNode:nodeUid",
254
- nodeRevisionUid: "newNode:nodeRevisionUid",
327
+ nodeUid: 'newNode:nodeUid',
328
+ nodeRevisionUid: 'newNode:nodeRevisionUid',
255
329
  nodeKeys: {
256
330
  key: { _idx: 32321 },
257
- contentKeyPacketSessionKey: "newNode:contentKeyPacketSessionKey",
331
+ contentKeyPacketSessionKey: 'newNode:contentKeyPacketSessionKey',
258
332
  signatureAddress: {
259
- email: "signatureEmail",
260
- addressId: "addressId",
261
- addressKey: "addressKey",
333
+ email: 'signatureEmail',
334
+ addressId: 'addressId',
335
+ addressKey: 'addressKey',
262
336
  } as any,
263
337
  },
264
338
  };
265
339
  const manifest = new Uint8Array([1, 2, 3]);
266
340
  const metadata = {
267
- mediaType: "myMimeType",
341
+ mediaType: 'myMimeType',
268
342
  expectedSize: 123456,
269
343
  };
270
344
  const extendedAttributes = {
271
345
  modificationTime: new Date(),
272
346
  digests: {
273
- sha1: "sha1",
274
- }
347
+ sha1: 'sha1',
348
+ },
275
349
  };
276
350
 
277
- it("should commit revision draft", async () => {
278
- await manager.commitDraft(
279
- nodeRevisionDraft as any,
351
+ it('should commit revision draft', async () => {
352
+ await manager.commitDraft(nodeRevisionDraft as any, manifest, metadata, extendedAttributes);
353
+
354
+ expect(cryptoService.commitFile).toHaveBeenCalledWith(
355
+ nodeRevisionDraft.nodeKeys,
280
356
  manifest,
281
- metadata,
282
- extendedAttributes,
283
- 1234567,
357
+ expect.anything(),
284
358
  );
359
+ expect(apiService.commitDraftRevision).toHaveBeenCalledWith(
360
+ nodeRevisionDraft.nodeRevisionUid,
361
+ expect.anything(),
362
+ );
363
+ expect(nodesService.notifyChildCreated).toHaveBeenCalledWith('parentUid');
364
+ });
285
365
 
286
- expect(cryptoService.commitFile).toHaveBeenCalledWith(nodeRevisionDraft.nodeKeys, manifest, expect.anything());
287
- expect(apiService.commitDraftRevision).toHaveBeenCalledWith(nodeRevisionDraft.nodeRevisionUid, expect.anything());
288
- expect(nodesEvents.nodeUpdated).toHaveBeenCalledWith({
289
- uid: "newNode:nodeUid",
290
- activeRevision: {
291
- ok: true,
292
- value: {
293
- uid: "newNode:nodeRevisionUid",
294
- state: RevisionState.Active,
295
- creationTime: expect.any(Date),
296
- contentAuthor: { ok: true, value: "signatureEmail" },
297
- storageSize: 1234567,
298
- claimedSize: 123456,
299
- claimedModificationTime: extendedAttributes.modificationTime,
300
- claimedDigests: {
301
- sha1: "sha1",
302
- },
303
- },
304
- },
305
- });
306
- })
307
-
308
- it("should commit node draft", async () => {
366
+ it('should commit node draft', async () => {
309
367
  const nodeRevisionDraftWithNewNodeInfo = {
310
368
  ...nodeRevisionDraft,
311
369
  newNodeInfo: {
312
- parentUid: "parentUid",
313
- name: "newNode:name",
314
- encryptedName: "newNode:encryptedName",
315
- hash: "newNode:hash",
316
- }
317
- }
318
- await manager.commitDraft(
319
- nodeRevisionDraftWithNewNodeInfo as any,
370
+ parentUid: 'parentUid',
371
+ name: 'newNode:name',
372
+ encryptedName: 'newNode:encryptedName',
373
+ hash: 'newNode:hash',
374
+ },
375
+ };
376
+ await manager.commitDraft(nodeRevisionDraftWithNewNodeInfo as any, manifest, metadata, extendedAttributes);
377
+
378
+ expect(cryptoService.commitFile).toHaveBeenCalledWith(
379
+ nodeRevisionDraft.nodeKeys,
320
380
  manifest,
321
- metadata,
322
- extendedAttributes,
323
- 1234567,
381
+ expect.anything(),
324
382
  );
325
-
326
- expect(cryptoService.commitFile).toHaveBeenCalledWith(nodeRevisionDraft.nodeKeys, manifest, expect.anything());
327
- expect(apiService.commitDraftRevision).toHaveBeenCalledWith(nodeRevisionDraft.nodeRevisionUid, expect.anything());
328
- expect(nodesEvents.nodeCreated).toHaveBeenCalledWith(expect.objectContaining({
329
- uid: "newNode:nodeUid",
330
- parentUid: "parentUid",
331
- type: NodeType.File,
332
- totalStorageSize: 1234567,
333
- activeRevision: {
334
- ok: true,
335
- value: expect.objectContaining({
336
- uid: "newNode:nodeRevisionUid",
337
- storageSize: 1234567,
338
- }),
339
- },
340
- }));
383
+ expect(apiService.commitDraftRevision).toHaveBeenCalledWith(
384
+ nodeRevisionDraft.nodeRevisionUid,
385
+ expect.anything(),
386
+ );
387
+ expect(nodesService.notifyChildCreated).toHaveBeenCalledWith('parentUid');
341
388
  });
342
389
  });
343
390
  });