@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.
- package/dist/cache/index.d.ts +1 -0
- package/dist/cache/index.js +3 -1
- package/dist/cache/index.js.map +1 -1
- package/dist/cache/memoryCache.d.ts +1 -1
- package/dist/cache/memoryCache.js +0 -1
- package/dist/cache/memoryCache.js.map +1 -1
- package/dist/cache/memoryCache.test.js +2 -4
- package/dist/cache/memoryCache.test.js.map +1 -1
- package/dist/cache/nullCache.d.ts +14 -0
- package/dist/cache/nullCache.js +36 -0
- package/dist/cache/nullCache.js.map +1 -0
- package/dist/config.d.ts +16 -1
- package/dist/config.js +1 -1
- package/dist/config.js.map +1 -1
- package/dist/crypto/driveCrypto.d.ts +2 -5
- package/dist/crypto/driveCrypto.js +7 -12
- package/dist/crypto/driveCrypto.js.map +1 -1
- package/dist/crypto/driveCrypto.test.js +14 -14
- package/dist/crypto/openPGPCrypto.js +5 -3
- package/dist/crypto/openPGPCrypto.js.map +1 -1
- package/dist/diagnostic/eventsGenerator.d.ts +14 -0
- package/dist/diagnostic/eventsGenerator.js +49 -0
- package/dist/diagnostic/eventsGenerator.js.map +1 -0
- package/dist/diagnostic/httpClient.d.ts +16 -0
- package/dist/diagnostic/httpClient.js +81 -0
- package/dist/diagnostic/httpClient.js.map +1 -0
- package/dist/diagnostic/index.d.ts +10 -0
- package/dist/diagnostic/index.js +35 -0
- package/dist/diagnostic/index.js.map +1 -0
- package/dist/diagnostic/integrityVerificationStream.d.ts +21 -0
- package/dist/diagnostic/integrityVerificationStream.js +56 -0
- package/dist/diagnostic/integrityVerificationStream.js.map +1 -0
- package/dist/diagnostic/interface.d.ts +102 -0
- package/dist/diagnostic/interface.js +3 -0
- package/dist/diagnostic/interface.js.map +1 -0
- package/dist/diagnostic/sdkDiagnostic.d.ts +22 -0
- package/dist/diagnostic/sdkDiagnostic.js +222 -0
- package/dist/diagnostic/sdkDiagnostic.js.map +1 -0
- package/dist/diagnostic/sdkDiagnosticFull.d.ts +18 -0
- package/dist/diagnostic/sdkDiagnosticFull.js +35 -0
- package/dist/diagnostic/sdkDiagnosticFull.js.map +1 -0
- package/dist/diagnostic/telemetry.d.ts +25 -0
- package/dist/diagnostic/telemetry.js +70 -0
- package/dist/diagnostic/telemetry.js.map +1 -0
- package/dist/diagnostic/zipGenerators.d.ts +9 -0
- package/dist/diagnostic/zipGenerators.js +64 -0
- package/dist/diagnostic/zipGenerators.js.map +1 -0
- package/dist/diagnostic/zipGenerators.test.js +144 -0
- package/dist/diagnostic/zipGenerators.test.js.map +1 -0
- package/dist/errors.d.ts +2 -1
- package/dist/errors.js +3 -1
- package/dist/errors.js.map +1 -1
- package/dist/interface/config.d.ts +26 -0
- package/dist/interface/config.js +3 -0
- package/dist/interface/config.js.map +1 -0
- package/dist/interface/download.d.ts +2 -2
- package/dist/interface/events.d.ts +58 -20
- package/dist/interface/events.js +11 -1
- package/dist/interface/events.js.map +1 -1
- package/dist/interface/httpClient.d.ts +0 -14
- package/dist/interface/index.d.ts +11 -7
- package/dist/interface/index.js +2 -2
- package/dist/interface/index.js.map +1 -1
- package/dist/interface/nodes.d.ts +9 -0
- package/dist/interface/nodes.js.map +1 -1
- package/dist/interface/result.js.map +1 -1
- package/dist/interface/sharing.d.ts +2 -0
- package/dist/interface/sharing.js.map +1 -1
- package/dist/interface/telemetry.js +0 -8
- package/dist/interface/telemetry.js.map +1 -1
- package/dist/interface/thumbnail.js.map +1 -1
- package/dist/interface/upload.d.ts +7 -1
- package/dist/internal/apiService/apiService.d.ts +1 -1
- package/dist/internal/apiService/apiService.js +7 -11
- package/dist/internal/apiService/apiService.js.map +1 -1
- package/dist/internal/apiService/apiService.test.js +55 -48
- package/dist/internal/apiService/apiService.test.js.map +1 -1
- package/dist/internal/apiService/coreTypes.d.ts +2356 -2356
- package/dist/internal/apiService/driveTypes.d.ts +1680 -1680
- package/dist/internal/apiService/errors.js +14 -8
- package/dist/internal/apiService/errors.js.map +1 -1
- package/dist/internal/apiService/errors.test.js +17 -12
- package/dist/internal/apiService/errors.test.js.map +1 -1
- package/dist/internal/apiService/transformers.d.ts +1 -1
- package/dist/internal/apiService/transformers.js +1 -1
- package/dist/internal/asyncIteratorMap.test.js +2 -2
- package/dist/internal/asyncIteratorMap.test.js.map +1 -1
- package/dist/internal/asyncIteratorRace.d.ts +13 -0
- package/dist/internal/asyncIteratorRace.js +59 -0
- package/dist/internal/asyncIteratorRace.js.map +1 -0
- package/dist/internal/asyncIteratorRace.test.d.ts +1 -0
- package/dist/internal/asyncIteratorRace.test.js +119 -0
- package/dist/internal/asyncIteratorRace.test.js.map +1 -0
- package/dist/internal/batch.d.ts +1 -0
- package/dist/internal/batch.js +12 -0
- package/dist/internal/batch.js.map +1 -0
- package/dist/internal/batch.test.d.ts +1 -0
- package/dist/internal/batch.test.js +41 -0
- package/dist/internal/batch.test.js.map +1 -0
- package/dist/internal/batchLoading.js.map +1 -1
- package/dist/internal/batchLoading.test.js +13 -13
- package/dist/internal/batchLoading.test.js.map +1 -1
- package/dist/internal/devices/apiService.d.ts +3 -3
- package/dist/internal/devices/apiService.js +2 -2
- package/dist/internal/devices/apiService.js.map +1 -1
- package/dist/internal/devices/cryptoService.js +1 -2
- package/dist/internal/devices/cryptoService.js.map +1 -1
- package/dist/internal/devices/index.d.ts +5 -5
- package/dist/internal/devices/index.js.map +1 -1
- package/dist/internal/devices/interface.d.ts +3 -3
- package/dist/internal/devices/manager.js +2 -2
- package/dist/internal/devices/manager.js.map +1 -1
- package/dist/internal/devices/manager.test.js +38 -7
- package/dist/internal/devices/manager.test.js.map +1 -1
- package/dist/internal/download/apiService.d.ts +4 -4
- package/dist/internal/download/apiService.js +32 -32
- package/dist/internal/download/apiService.js.map +1 -1
- package/dist/internal/download/cryptoService.d.ts +4 -4
- package/dist/internal/download/cryptoService.js +6 -5
- package/dist/internal/download/cryptoService.js.map +1 -1
- package/dist/internal/download/fileDownloader.d.ts +6 -6
- package/dist/internal/download/fileDownloader.js +3 -2
- package/dist/internal/download/fileDownloader.js.map +1 -1
- package/dist/internal/download/fileDownloader.test.js +1 -1
- package/dist/internal/download/fileDownloader.test.js.map +1 -1
- package/dist/internal/download/index.d.ts +5 -5
- package/dist/internal/download/index.js +5 -5
- package/dist/internal/download/index.js.map +1 -1
- package/dist/internal/download/interface.d.ts +3 -4
- package/dist/internal/download/telemetry.d.ts +3 -3
- package/dist/internal/download/telemetry.js +4 -2
- package/dist/internal/download/telemetry.js.map +1 -1
- package/dist/internal/download/telemetry.test.js +8 -8
- package/dist/internal/download/telemetry.test.js.map +1 -1
- package/dist/internal/download/thumbnailDownloader.d.ts +4 -4
- package/dist/internal/download/thumbnailDownloader.js +6 -6
- package/dist/internal/download/thumbnailDownloader.js.map +1 -1
- package/dist/internal/download/thumbnailDownloader.test.js.map +1 -1
- package/dist/internal/errors.d.ts +1 -1
- package/dist/internal/errors.js +1 -3
- package/dist/internal/errors.js.map +1 -1
- package/dist/internal/events/apiService.d.ts +5 -7
- package/dist/internal/events/apiService.js +19 -22
- package/dist/internal/events/apiService.js.map +1 -1
- package/dist/internal/events/coreEventManager.d.ts +9 -12
- package/dist/internal/events/coreEventManager.js +19 -36
- package/dist/internal/events/coreEventManager.js.map +1 -1
- package/dist/internal/events/coreEventManager.test.d.ts +1 -0
- package/dist/internal/events/coreEventManager.test.js +87 -0
- package/dist/internal/events/coreEventManager.test.js.map +1 -0
- package/dist/internal/events/eventManager.d.ts +11 -36
- package/dist/internal/events/eventManager.js +59 -106
- package/dist/internal/events/eventManager.js.map +1 -1
- package/dist/internal/events/eventManager.test.js +177 -83
- package/dist/internal/events/eventManager.test.js.map +1 -1
- package/dist/internal/events/index.d.ts +16 -36
- package/dist/internal/events/index.js +56 -72
- package/dist/internal/events/index.js.map +1 -1
- package/dist/internal/events/interface.d.ts +59 -14
- package/dist/internal/events/interface.js +12 -3
- package/dist/internal/events/interface.js.map +1 -1
- package/dist/internal/events/volumeEventManager.d.ts +9 -19
- package/dist/internal/events/volumeEventManager.js +58 -45
- package/dist/internal/events/volumeEventManager.js.map +1 -1
- package/dist/internal/events/volumeEventManager.test.d.ts +1 -0
- package/dist/internal/events/volumeEventManager.test.js +203 -0
- package/dist/internal/events/volumeEventManager.test.js.map +1 -0
- package/dist/internal/nodes/apiService.d.ts +4 -3
- package/dist/internal/nodes/apiService.js +36 -15
- package/dist/internal/nodes/apiService.js.map +1 -1
- package/dist/internal/nodes/apiService.test.js +60 -41
- package/dist/internal/nodes/apiService.test.js.map +1 -1
- package/dist/internal/nodes/cache.d.ts +14 -5
- package/dist/internal/nodes/cache.js +31 -7
- package/dist/internal/nodes/cache.js.map +1 -1
- package/dist/internal/nodes/cache.test.js +31 -9
- package/dist/internal/nodes/cache.test.js.map +1 -1
- package/dist/internal/nodes/cryptoCache.d.ts +2 -2
- package/dist/internal/nodes/cryptoCache.js.map +1 -1
- package/dist/internal/nodes/cryptoCache.test.js +24 -4
- package/dist/internal/nodes/cryptoCache.test.js.map +1 -1
- package/dist/internal/nodes/cryptoService.d.ts +4 -4
- package/dist/internal/nodes/cryptoService.js +11 -17
- package/dist/internal/nodes/cryptoService.js.map +1 -1
- package/dist/internal/nodes/cryptoService.test.js +320 -241
- package/dist/internal/nodes/cryptoService.test.js.map +1 -1
- package/dist/internal/nodes/events.d.ts +8 -84
- package/dist/internal/nodes/events.js +43 -217
- package/dist/internal/nodes/events.js.map +1 -1
- package/dist/internal/nodes/events.test.js +35 -279
- package/dist/internal/nodes/events.test.js.map +1 -1
- package/dist/internal/nodes/extendedAttributes.d.ts +1 -1
- package/dist/internal/nodes/extendedAttributes.js +3 -1
- package/dist/internal/nodes/extendedAttributes.js.map +1 -1
- package/dist/internal/nodes/extendedAttributes.test.js +7 -10
- package/dist/internal/nodes/extendedAttributes.test.js.map +1 -1
- package/dist/internal/nodes/index.d.ts +12 -13
- package/dist/internal/nodes/index.js +5 -5
- package/dist/internal/nodes/index.js.map +1 -1
- package/dist/internal/nodes/index.test.js +24 -32
- package/dist/internal/nodes/index.test.js.map +1 -1
- package/dist/internal/nodes/interface.d.ts +2 -2
- package/dist/internal/nodes/nodesAccess.d.ts +22 -7
- package/dist/internal/nodes/nodesAccess.js +65 -16
- package/dist/internal/nodes/nodesAccess.js.map +1 -1
- package/dist/internal/nodes/nodesAccess.test.js +165 -101
- package/dist/internal/nodes/nodesAccess.test.js.map +1 -1
- package/dist/internal/nodes/nodesManagement.d.ts +7 -9
- package/dist/internal/nodes/nodesManagement.js +21 -33
- package/dist/internal/nodes/nodesManagement.js.map +1 -1
- package/dist/internal/nodes/nodesManagement.test.js +42 -21
- package/dist/internal/nodes/nodesManagement.test.js.map +1 -1
- package/dist/internal/nodes/nodesRevisions.d.ts +4 -4
- package/dist/internal/nodes/nodesRevisions.js.map +1 -1
- package/dist/internal/photos/albums.d.ts +3 -3
- package/dist/internal/photos/albums.js.map +1 -1
- package/dist/internal/photos/apiService.d.ts +1 -1
- package/dist/internal/photos/apiService.js +3 -6
- package/dist/internal/photos/apiService.js.map +1 -1
- package/dist/internal/photos/cache.d.ts +1 -1
- package/dist/internal/photos/index.d.ts +5 -5
- package/dist/internal/photos/index.js.map +1 -1
- package/dist/internal/photos/interface.d.ts +2 -2
- package/dist/internal/photos/photosTimeline.d.ts +3 -3
- package/dist/internal/photos/photosTimeline.js +1 -2
- package/dist/internal/photos/photosTimeline.js.map +1 -1
- package/dist/internal/sdkEvents.d.ts +1 -1
- package/dist/internal/sdkEvents.js +2 -7
- package/dist/internal/sdkEvents.js.map +1 -1
- package/dist/internal/sdkEvents.test.js +8 -8
- package/dist/internal/shares/apiService.d.ts +2 -2
- package/dist/internal/shares/apiService.js +5 -3
- package/dist/internal/shares/apiService.js.map +1 -1
- package/dist/internal/shares/cache.d.ts +4 -2
- package/dist/internal/shares/cache.js +14 -6
- package/dist/internal/shares/cache.js.map +1 -1
- package/dist/internal/shares/cache.test.js.map +1 -1
- package/dist/internal/shares/cryptoCache.d.ts +2 -2
- package/dist/internal/shares/cryptoCache.test.js +8 -2
- package/dist/internal/shares/cryptoCache.test.js.map +1 -1
- package/dist/internal/shares/cryptoService.d.ts +3 -3
- package/dist/internal/shares/cryptoService.js.map +1 -1
- package/dist/internal/shares/cryptoService.test.js +42 -42
- package/dist/internal/shares/cryptoService.test.js.map +1 -1
- package/dist/internal/shares/index.d.ts +4 -4
- package/dist/internal/shares/index.js.map +1 -1
- package/dist/internal/shares/interface.d.ts +2 -2
- package/dist/internal/shares/manager.d.ts +8 -7
- package/dist/internal/shares/manager.js +3 -0
- package/dist/internal/shares/manager.js.map +1 -1
- package/dist/internal/shares/manager.test.js +71 -63
- package/dist/internal/shares/manager.test.js.map +1 -1
- package/dist/internal/sharing/apiService.d.ts +4 -4
- package/dist/internal/sharing/apiService.js +5 -3
- package/dist/internal/sharing/apiService.js.map +1 -1
- package/dist/internal/sharing/cache.d.ts +1 -1
- package/dist/internal/sharing/cache.test.js +33 -33
- package/dist/internal/sharing/cryptoService.d.ts +3 -3
- package/dist/internal/sharing/cryptoService.js +3 -4
- package/dist/internal/sharing/cryptoService.js.map +1 -1
- package/dist/internal/sharing/cryptoService.test.js +39 -39
- package/dist/internal/sharing/cryptoService.test.js.map +1 -1
- package/dist/internal/sharing/events.d.ts +24 -56
- package/dist/internal/sharing/events.js +45 -138
- package/dist/internal/sharing/events.js.map +1 -1
- package/dist/internal/sharing/events.test.js +85 -189
- package/dist/internal/sharing/events.test.js.map +1 -1
- package/dist/internal/sharing/index.d.ts +8 -9
- package/dist/internal/sharing/index.js +5 -5
- package/dist/internal/sharing/index.js.map +1 -1
- package/dist/internal/sharing/interface.d.ts +8 -4
- package/dist/internal/sharing/sharingAccess.d.ts +6 -6
- package/dist/internal/sharing/sharingAccess.js +8 -4
- package/dist/internal/sharing/sharingAccess.js.map +1 -1
- package/dist/internal/sharing/sharingAccess.test.js +45 -39
- package/dist/internal/sharing/sharingAccess.test.js.map +1 -1
- package/dist/internal/sharing/sharingManagement.d.ts +5 -6
- package/dist/internal/sharing/sharingManagement.js +12 -16
- package/dist/internal/sharing/sharingManagement.js.map +1 -1
- package/dist/internal/sharing/sharingManagement.test.js +305 -286
- package/dist/internal/sharing/sharingManagement.test.js.map +1 -1
- package/dist/internal/uids.js.map +1 -1
- package/dist/internal/upload/apiService.d.ts +5 -6
- package/dist/internal/upload/apiService.js +8 -5
- package/dist/internal/upload/apiService.js.map +1 -1
- package/dist/internal/upload/blockVerifier.d.ts +3 -3
- package/dist/internal/upload/blockVerifier.js +1 -1
- package/dist/internal/upload/blockVerifier.js.map +1 -1
- package/dist/internal/upload/chunkStreamReader.test.js +6 -6
- package/dist/internal/upload/cryptoService.d.ts +4 -4
- package/dist/internal/upload/cryptoService.js +4 -4
- package/dist/internal/upload/cryptoService.js.map +1 -1
- package/dist/internal/upload/digests.js.map +1 -1
- package/dist/internal/upload/fileUploader.d.ts +6 -6
- package/dist/internal/upload/fileUploader.js.map +1 -1
- package/dist/internal/upload/fileUploader.test.js.map +1 -1
- package/dist/internal/upload/index.d.ts +6 -6
- package/dist/internal/upload/index.js +3 -3
- package/dist/internal/upload/index.js.map +1 -1
- package/dist/internal/upload/interface.d.ts +5 -3
- package/dist/internal/upload/manager.d.ts +8 -8
- package/dist/internal/upload/manager.js +23 -52
- package/dist/internal/upload/manager.js.map +1 -1
- package/dist/internal/upload/manager.test.js +185 -147
- package/dist/internal/upload/manager.test.js.map +1 -1
- package/dist/internal/upload/streamUploader.d.ts +6 -6
- package/dist/internal/upload/streamUploader.js +9 -8
- package/dist/internal/upload/streamUploader.js.map +1 -1
- package/dist/internal/upload/streamUploader.test.js +17 -12
- package/dist/internal/upload/streamUploader.test.js.map +1 -1
- package/dist/internal/upload/telemetry.d.ts +3 -3
- package/dist/internal/upload/telemetry.js +5 -3
- package/dist/internal/upload/telemetry.js.map +1 -1
- package/dist/internal/upload/telemetry.test.js +8 -8
- package/dist/internal/upload/telemetry.test.js.map +1 -1
- package/dist/protonDriveClient.d.ts +27 -170
- package/dist/protonDriveClient.js +37 -198
- package/dist/protonDriveClient.js.map +1 -1
- package/dist/protonDrivePhotosClient.js +3 -2
- package/dist/protonDrivePhotosClient.js.map +1 -1
- package/dist/telemetry.js +18 -15
- package/dist/telemetry.js.map +1 -1
- package/dist/tests/logger.js.map +1 -1
- package/dist/tests/telemetry.d.ts +1 -1
- package/dist/transformers.js +4 -2
- package/dist/transformers.js.map +1 -1
- package/package.json +3 -3
- package/src/cache/index.ts +1 -0
- package/src/cache/interface.ts +22 -22
- package/src/cache/memoryCache.test.ts +7 -7
- package/src/cache/memoryCache.ts +5 -5
- package/src/cache/nullCache.ts +38 -0
- package/src/config.ts +17 -2
- package/src/crypto/driveCrypto.test.ts +15 -15
- package/src/crypto/driveCrypto.ts +120 -156
- package/src/crypto/hmac.ts +1 -1
- package/src/crypto/interface.ts +63 -72
- package/src/crypto/openPGPCrypto.ts +76 -94
- package/src/crypto/utils.ts +1 -1
- package/src/diagnostic/eventsGenerator.ts +48 -0
- package/src/diagnostic/httpClient.ts +84 -0
- package/src/diagnostic/index.ts +40 -0
- package/src/diagnostic/integrityVerificationStream.ts +55 -0
- package/src/diagnostic/interface.ts +158 -0
- package/src/diagnostic/sdkDiagnostic.ts +249 -0
- package/src/diagnostic/sdkDiagnosticFull.ts +37 -0
- package/src/diagnostic/telemetry.ts +74 -0
- package/src/diagnostic/zipGenerators.test.ts +177 -0
- package/src/diagnostic/zipGenerators.ts +70 -0
- package/src/errors.ts +25 -22
- package/src/index.ts +3 -3
- package/src/interface/account.ts +10 -10
- package/src/interface/author.ts +6 -6
- package/src/interface/config.ts +28 -0
- package/src/interface/devices.ts +6 -6
- package/src/interface/download.ts +12 -9
- package/src/interface/events.ts +76 -25
- package/src/interface/httpClient.ts +11 -27
- package/src/interface/index.ts +81 -20
- package/src/interface/nodes.ts +67 -60
- package/src/interface/result.ts +1 -3
- package/src/interface/sharing.ts +60 -56
- package/src/interface/telemetry.ts +74 -74
- package/src/interface/thumbnail.ts +5 -6
- package/src/interface/upload.ts +25 -11
- package/src/internal/apiService/apiService.test.ts +109 -76
- package/src/internal/apiService/apiService.ts +40 -26
- package/src/internal/apiService/coreTypes.ts +2474 -2463
- package/src/internal/apiService/driveTypes.ts +1868 -1822
- package/src/internal/apiService/errorCodes.ts +4 -4
- package/src/internal/apiService/errors.test.ts +25 -23
- package/src/internal/apiService/errors.ts +15 -9
- package/src/internal/apiService/index.ts +1 -1
- package/src/internal/apiService/transformers.ts +2 -2
- package/src/internal/asyncIteratorMap.test.ts +4 -4
- package/src/internal/asyncIteratorMap.ts +1 -1
- package/src/internal/asyncIteratorRace.test.ts +149 -0
- package/src/internal/asyncIteratorRace.ts +79 -0
- package/src/internal/batch.test.ts +50 -0
- package/src/internal/batch.ts +9 -0
- package/src/internal/batchLoading.test.ts +13 -14
- package/src/internal/batchLoading.ts +8 -8
- package/src/internal/devices/apiService.ts +58 -51
- package/src/internal/devices/cryptoService.ts +22 -17
- package/src/internal/devices/index.ts +17 -10
- package/src/internal/devices/interface.ts +21 -12
- package/src/internal/devices/manager.test.ts +40 -9
- package/src/internal/devices/manager.ts +3 -3
- package/src/internal/download/apiService.ts +72 -52
- package/src/internal/download/cryptoService.ts +34 -18
- package/src/internal/download/fileDownloader.test.ts +25 -9
- package/src/internal/download/fileDownloader.ts +38 -20
- package/src/internal/download/index.ts +19 -19
- package/src/internal/download/interface.ts +19 -20
- package/src/internal/download/queue.ts +3 -3
- package/src/internal/download/telemetry.test.ts +11 -11
- package/src/internal/download/telemetry.ts +24 -14
- package/src/internal/download/thumbnailDownloader.test.ts +11 -6
- package/src/internal/download/thumbnailDownloader.ts +43 -32
- package/src/internal/errors.ts +7 -5
- package/src/internal/events/apiService.ts +46 -36
- package/src/internal/events/coreEventManager.test.ts +101 -0
- package/src/internal/events/coreEventManager.ts +26 -48
- package/src/internal/events/eventManager.test.ts +211 -93
- package/src/internal/events/eventManager.ts +72 -117
- package/src/internal/events/index.ts +71 -91
- package/src/internal/events/interface.ts +92 -29
- package/src/internal/events/volumeEventManager.test.ts +239 -0
- package/src/internal/events/volumeEventManager.ts +68 -57
- package/src/internal/nodes/apiService.test.ts +197 -147
- package/src/internal/nodes/apiService.ts +288 -174
- package/src/internal/nodes/cache.test.ts +48 -20
- package/src/internal/nodes/cache.ts +79 -45
- package/src/internal/nodes/cryptoCache.test.ts +34 -14
- package/src/internal/nodes/cryptoCache.ts +10 -5
- package/src/internal/nodes/cryptoService.test.ts +492 -351
- package/src/internal/nodes/cryptoService.ts +171 -89
- package/src/internal/nodes/events.test.ts +48 -344
- package/src/internal/nodes/events.ts +48 -254
- package/src/internal/nodes/extendedAttributes.test.ts +28 -24
- package/src/internal/nodes/extendedAttributes.ts +20 -15
- package/src/internal/nodes/index.test.ts +51 -55
- package/src/internal/nodes/index.ts +32 -22
- package/src/internal/nodes/interface.ts +44 -31
- package/src/internal/nodes/nodesAccess.test.ts +237 -130
- package/src/internal/nodes/nodesAccess.ts +113 -50
- package/src/internal/nodes/nodesManagement.test.ts +64 -39
- package/src/internal/nodes/nodesManagement.ts +51 -62
- package/src/internal/nodes/nodesRevisions.ts +7 -7
- package/src/internal/nodes/validations.ts +2 -2
- package/src/internal/photos/albums.ts +5 -5
- package/src/internal/photos/apiService.ts +4 -7
- package/src/internal/photos/cache.ts +1 -1
- package/src/internal/photos/index.ts +8 -8
- package/src/internal/photos/interface.ts +2 -2
- package/src/internal/photos/photosTimeline.ts +4 -5
- package/src/internal/sdkEvents.test.ts +10 -10
- package/src/internal/sdkEvents.ts +5 -13
- package/src/internal/shares/apiService.ts +44 -33
- package/src/internal/shares/cache.test.ts +6 -4
- package/src/internal/shares/cache.ts +25 -14
- package/src/internal/shares/cryptoCache.test.ts +17 -11
- package/src/internal/shares/cryptoCache.ts +4 -4
- package/src/internal/shares/cryptoService.test.ts +72 -74
- package/src/internal/shares/cryptoService.ts +48 -23
- package/src/internal/shares/index.ts +23 -11
- package/src/internal/shares/interface.ts +8 -8
- package/src/internal/shares/manager.test.ts +88 -80
- package/src/internal/shares/manager.ts +27 -23
- package/src/internal/sharing/apiService.ts +283 -175
- package/src/internal/sharing/cache.test.ts +35 -35
- package/src/internal/sharing/cache.ts +3 -3
- package/src/internal/sharing/cryptoService.test.ts +58 -46
- package/src/internal/sharing/cryptoService.ts +121 -83
- package/src/internal/sharing/events.test.ts +97 -207
- package/src/internal/sharing/events.ts +46 -157
- package/src/internal/sharing/index.ts +24 -16
- package/src/internal/sharing/interface.ts +46 -42
- package/src/internal/sharing/sharingAccess.test.ts +71 -65
- package/src/internal/sharing/sharingAccess.ts +39 -21
- package/src/internal/sharing/sharingManagement.test.ts +405 -335
- package/src/internal/sharing/sharingManagement.ts +144 -75
- package/src/internal/uids.ts +1 -1
- package/src/internal/upload/apiService.ts +168 -119
- package/src/internal/upload/blockVerifier.ts +8 -6
- package/src/internal/upload/chunkStreamReader.test.ts +7 -7
- package/src/internal/upload/cryptoService.ts +42 -36
- package/src/internal/upload/digests.ts +2 -2
- package/src/internal/upload/fileUploader.test.ts +15 -3
- package/src/internal/upload/fileUploader.ts +39 -17
- package/src/internal/upload/index.ts +17 -18
- package/src/internal/upload/interface.ts +79 -77
- package/src/internal/upload/manager.test.ts +222 -175
- package/src/internal/upload/manager.ts +74 -80
- package/src/internal/upload/queue.ts +3 -3
- package/src/internal/upload/streamUploader.test.ts +40 -27
- package/src/internal/upload/streamUploader.ts +87 -71
- package/src/internal/upload/telemetry.test.ts +11 -11
- package/src/internal/upload/telemetry.ts +25 -15
- package/src/internal/wait.test.ts +1 -1
- package/src/internal/wait.ts +3 -3
- package/src/protonDriveClient.ts +189 -276
- package/src/protonDrivePhotosClient.ts +20 -13
- package/src/telemetry.ts +60 -52
- package/src/tests/logger.ts +1 -1
- package/src/tests/telemetry.ts +2 -2
- package/src/transformers.ts +27 -21
- package/src/version.ts +0 -1
- package/dist/internal/events/cache.d.ts +0 -28
- package/dist/internal/events/cache.js +0 -67
- package/dist/internal/events/cache.js.map +0 -1
- package/dist/internal/events/cache.test.js +0 -43
- package/dist/internal/events/cache.test.js.map +0 -1
- package/src/internal/events/cache.test.ts +0 -47
- package/src/internal/events/cache.ts +0 -80
- /package/dist/{internal/events/cache.test.d.ts → diagnostic/zipGenerators.test.d.ts} +0 -0
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { c } from 'ttag';
|
|
2
2
|
|
|
3
|
-
import { NodeType, ThumbnailType, ProtonDriveTelemetry, Logger, ThumbnailResult } from
|
|
3
|
+
import { NodeType, ThumbnailType, ProtonDriveTelemetry, Logger, ThumbnailResult } from '../../interface';
|
|
4
4
|
import { ValidationError } from '../../errors';
|
|
5
5
|
import { LoggerWithPrefix } from '../../telemetry';
|
|
6
|
-
import { DownloadAPIService } from
|
|
7
|
-
import { DownloadCryptoService } from
|
|
8
|
-
import { NodesService } from
|
|
6
|
+
import { DownloadAPIService } from './apiService';
|
|
7
|
+
import { DownloadCryptoService } from './cryptoService';
|
|
8
|
+
import { NodesService } from './interface';
|
|
9
9
|
import { getErrorMessage } from '../errors';
|
|
10
10
|
|
|
11
11
|
/**
|
|
@@ -24,8 +24,8 @@ export class ThumbnailDownloader {
|
|
|
24
24
|
private batchThumbnailToNodeUids = new Map<string, string>();
|
|
25
25
|
private ongoingDownloads = new Map<string, Promise<void>>();
|
|
26
26
|
private bufferedThumbnails: (
|
|
27
|
-
{ nodeUid: string
|
|
28
|
-
{ nodeUid: string
|
|
27
|
+
| { nodeUid: string; ok: true; thumbnail: Uint8Array }
|
|
28
|
+
| { nodeUid: string; ok: false; error: string }
|
|
29
29
|
)[] = [];
|
|
30
30
|
|
|
31
31
|
constructor(
|
|
@@ -34,7 +34,7 @@ export class ThumbnailDownloader {
|
|
|
34
34
|
private apiService: DownloadAPIService,
|
|
35
35
|
private cryptoService: DownloadCryptoService,
|
|
36
36
|
) {
|
|
37
|
-
this.logger = telemetry.getLogger(
|
|
37
|
+
this.logger = telemetry.getLogger('download');
|
|
38
38
|
this.nodesService = nodesService;
|
|
39
39
|
this.apiService = apiService;
|
|
40
40
|
this.cryptoService = cryptoService;
|
|
@@ -79,40 +79,41 @@ export class ThumbnailDownloader {
|
|
|
79
79
|
this.bufferedThumbnails = [];
|
|
80
80
|
}
|
|
81
81
|
|
|
82
|
-
private async *iterateThumbnailUids(
|
|
83
|
-
|
|
84
|
-
|
|
82
|
+
private async *iterateThumbnailUids(
|
|
83
|
+
nodeUids: string[],
|
|
84
|
+
thumbnailType: ThumbnailType,
|
|
85
|
+
signal?: AbortSignal,
|
|
86
|
+
): AsyncGenerator<
|
|
87
|
+
{ nodeUid: string; ok: true; thumbnailUid: string } | { nodeUid: string; ok: false; error: string }
|
|
85
88
|
> {
|
|
86
89
|
for await (const node of this.nodesService.iterateNodes(nodeUids, signal)) {
|
|
87
90
|
if ('missingUid' in node) {
|
|
88
91
|
yield {
|
|
89
92
|
nodeUid: node.missingUid,
|
|
90
93
|
ok: false,
|
|
91
|
-
error: c(
|
|
92
|
-
}
|
|
94
|
+
error: c('Error').t`Node not found`,
|
|
95
|
+
};
|
|
93
96
|
continue;
|
|
94
97
|
}
|
|
95
98
|
if (node.type !== NodeType.File) {
|
|
96
99
|
yield {
|
|
97
100
|
nodeUid: node.uid,
|
|
98
101
|
ok: false,
|
|
99
|
-
error: c(
|
|
100
|
-
}
|
|
102
|
+
error: c('Error').t`Node is not a file`,
|
|
103
|
+
};
|
|
101
104
|
continue;
|
|
102
105
|
}
|
|
103
106
|
|
|
104
107
|
let thumbnail;
|
|
105
108
|
if (node.activeRevision?.ok) {
|
|
106
|
-
thumbnail = node.activeRevision.value.thumbnails?.find(
|
|
107
|
-
(t) => t.type === thumbnailType,
|
|
108
|
-
);
|
|
109
|
+
thumbnail = node.activeRevision.value.thumbnails?.find((t) => t.type === thumbnailType);
|
|
109
110
|
}
|
|
110
111
|
if (!thumbnail) {
|
|
111
112
|
yield {
|
|
112
113
|
nodeUid: node.uid,
|
|
113
114
|
ok: false,
|
|
114
|
-
error: c(
|
|
115
|
-
}
|
|
115
|
+
error: c('Error').t`Node has no thumbnail`,
|
|
116
|
+
};
|
|
116
117
|
continue;
|
|
117
118
|
}
|
|
118
119
|
|
|
@@ -120,7 +121,7 @@ export class ThumbnailDownloader {
|
|
|
120
121
|
nodeUid: node.uid,
|
|
121
122
|
ok: true,
|
|
122
123
|
thumbnailUid: thumbnail.uid,
|
|
123
|
-
}
|
|
124
|
+
};
|
|
124
125
|
}
|
|
125
126
|
}
|
|
126
127
|
|
|
@@ -163,13 +164,15 @@ export class ThumbnailDownloader {
|
|
|
163
164
|
}),
|
|
164
165
|
);
|
|
165
166
|
}
|
|
166
|
-
|
|
167
|
+
|
|
167
168
|
this.batchThumbnailToNodeUids.clear();
|
|
168
169
|
}
|
|
169
170
|
|
|
170
|
-
private async *iterateThumbnailDownloads(
|
|
171
|
-
|
|
172
|
-
|
|
171
|
+
private async *iterateThumbnailDownloads(
|
|
172
|
+
signal?: AbortSignal,
|
|
173
|
+
): AsyncGenerator<
|
|
174
|
+
| { nodeUid: string; ok: true; downloadPromise: Promise<Uint8Array> }
|
|
175
|
+
| { nodeUid: string; ok: false; error: string }
|
|
173
176
|
> {
|
|
174
177
|
const missingThumbnailUids = new Set(this.batchThumbnailToNodeUids.keys());
|
|
175
178
|
|
|
@@ -190,7 +193,7 @@ export class ThumbnailDownloader {
|
|
|
190
193
|
nodeUid,
|
|
191
194
|
ok: false,
|
|
192
195
|
error: result.error,
|
|
193
|
-
}
|
|
196
|
+
};
|
|
194
197
|
continue;
|
|
195
198
|
}
|
|
196
199
|
|
|
@@ -198,7 +201,7 @@ export class ThumbnailDownloader {
|
|
|
198
201
|
nodeUid,
|
|
199
202
|
ok: true,
|
|
200
203
|
downloadPromise: this.downloadThumbnail(nodeUid, result.bareUrl, result.token, signal),
|
|
201
|
-
}
|
|
204
|
+
};
|
|
202
205
|
}
|
|
203
206
|
|
|
204
207
|
for (const uid of missingThumbnailUids) {
|
|
@@ -207,14 +210,19 @@ export class ThumbnailDownloader {
|
|
|
207
210
|
yield {
|
|
208
211
|
nodeUid,
|
|
209
212
|
ok: false,
|
|
210
|
-
error: c(
|
|
211
|
-
}
|
|
213
|
+
error: c('Error').t`Thumbnail not found`,
|
|
214
|
+
};
|
|
212
215
|
}
|
|
213
216
|
}
|
|
214
217
|
|
|
215
|
-
private async downloadThumbnail(
|
|
218
|
+
private async downloadThumbnail(
|
|
219
|
+
nodeUid: string,
|
|
220
|
+
bareUrl: string,
|
|
221
|
+
token: string,
|
|
222
|
+
signal?: AbortSignal,
|
|
223
|
+
): Promise<Uint8Array> {
|
|
216
224
|
const logger = new LoggerWithPrefix(this.logger, `thumbnail ${token}`);
|
|
217
|
-
|
|
225
|
+
|
|
218
226
|
let decryptedBlock: Uint8Array | null = null;
|
|
219
227
|
let attempt = 0;
|
|
220
228
|
|
|
@@ -229,11 +237,14 @@ export class ThumbnailDownloader {
|
|
|
229
237
|
]);
|
|
230
238
|
|
|
231
239
|
if (!nodeKeys.contentKeyPacketSessionKey) {
|
|
232
|
-
throw new ValidationError(c(
|
|
240
|
+
throw new ValidationError(c('Error').t`File has no content key`);
|
|
233
241
|
}
|
|
234
242
|
|
|
235
243
|
logger.debug(`Decrypting`);
|
|
236
|
-
decryptedBlock = await this.cryptoService.decryptThumbnail(
|
|
244
|
+
decryptedBlock = await this.cryptoService.decryptThumbnail(
|
|
245
|
+
encryptedBlock,
|
|
246
|
+
nodeKeys.contentKeyPacketSessionKey,
|
|
247
|
+
);
|
|
237
248
|
} catch (error: unknown) {
|
|
238
249
|
if (attempt <= MAX_THUMBNAIL_DOWNLOAD_ATTEMPTS) {
|
|
239
250
|
logger.warn(`Thumbnail download failed #${attempt}, retrying: ${getErrorMessage(error)}`);
|
package/src/internal/errors.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { c } from 'ttag';
|
|
2
2
|
|
|
3
|
-
import { VERIFICATION_STATUS } from
|
|
3
|
+
import { VERIFICATION_STATUS } from '../crypto';
|
|
4
4
|
|
|
5
5
|
export function getErrorMessage(error: unknown): string {
|
|
6
6
|
return error instanceof Error ? error.message : c('Error').t`Unknown error`;
|
|
@@ -9,11 +9,13 @@ export function getErrorMessage(error: unknown): string {
|
|
|
9
9
|
/**
|
|
10
10
|
* @param signatureType - Must be translated before calling this function.
|
|
11
11
|
*/
|
|
12
|
-
export function getVerificationMessage(
|
|
12
|
+
export function getVerificationMessage(
|
|
13
|
+
verified: VERIFICATION_STATUS,
|
|
14
|
+
signatureType?: string,
|
|
15
|
+
notAvailableVerificationKeys = false,
|
|
16
|
+
): string {
|
|
13
17
|
if (verified === VERIFICATION_STATUS.NOT_SIGNED) {
|
|
14
|
-
return signatureType
|
|
15
|
-
? c('Error').t`Missing signature for ${signatureType}`
|
|
16
|
-
: c('Error').t`Missing signature`;
|
|
18
|
+
return signatureType ? c('Error').t`Missing signature for ${signatureType}` : c('Error').t`Missing signature`;
|
|
17
19
|
}
|
|
18
20
|
|
|
19
21
|
if (notAvailableVerificationKeys) {
|
|
@@ -1,31 +1,36 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { DriveEvents, DriveEvent, DriveEventType } from "./interface";
|
|
1
|
+
import { DriveAPIService, drivePaths, corePaths } from '../apiService';
|
|
2
|
+
import { makeNodeUid } from '../uids';
|
|
3
|
+
import { DriveEventsListWithStatus, DriveEvent, DriveEventType, NodeEvent, NodeEventType } from './interface';
|
|
5
4
|
|
|
6
|
-
type GetCoreLatestEventResponse =
|
|
7
|
-
|
|
5
|
+
type GetCoreLatestEventResponse =
|
|
6
|
+
corePaths['/core/{_version}/events/latest']['get']['responses']['200']['content']['application/json'];
|
|
7
|
+
type GetCoreEventResponse =
|
|
8
|
+
corePaths['/core/{_version}/events/{id}']['get']['responses']['200']['content']['application/json'];
|
|
8
9
|
|
|
9
|
-
type GetVolumeLatestEventResponse =
|
|
10
|
-
|
|
10
|
+
type GetVolumeLatestEventResponse =
|
|
11
|
+
drivePaths['/drive/volumes/{volumeID}/events/latest']['get']['responses']['200']['content']['application/json'];
|
|
12
|
+
type GetVolumeEventResponse =
|
|
13
|
+
drivePaths['/drive/v2/volumes/{volumeID}/events/{eventID}']['get']['responses']['200']['content']['application/json'];
|
|
11
14
|
|
|
12
|
-
|
|
15
|
+
interface VolumeEventTypeMap {
|
|
16
|
+
[key: number]: NodeEventType;
|
|
17
|
+
}
|
|
18
|
+
const VOLUME_EVENT_TYPE_MAP: VolumeEventTypeMap = {
|
|
13
19
|
0: DriveEventType.NodeDeleted,
|
|
14
20
|
1: DriveEventType.NodeCreated,
|
|
15
21
|
2: DriveEventType.NodeUpdated,
|
|
16
|
-
3: DriveEventType.
|
|
17
|
-
}
|
|
22
|
+
3: DriveEventType.NodeUpdated,
|
|
23
|
+
};
|
|
18
24
|
|
|
19
25
|
/**
|
|
20
26
|
* Provides API communication for fetching events.
|
|
21
|
-
*
|
|
27
|
+
*
|
|
22
28
|
* The service is responsible for transforming local objects to API payloads
|
|
23
29
|
* and vice versa. It should not contain any business logic.
|
|
24
30
|
*/
|
|
25
31
|
export class EventsAPIService {
|
|
26
|
-
constructor(private apiService: DriveAPIService
|
|
32
|
+
constructor(private apiService: DriveAPIService) {
|
|
27
33
|
this.apiService = apiService;
|
|
28
|
-
this.logger = logger;
|
|
29
34
|
}
|
|
30
35
|
|
|
31
36
|
async getCoreLatestEventId(): Promise<string> {
|
|
@@ -33,17 +38,24 @@ export class EventsAPIService {
|
|
|
33
38
|
return result.EventID as string;
|
|
34
39
|
}
|
|
35
40
|
|
|
36
|
-
async getCoreEvents(eventId: string): Promise<
|
|
37
|
-
// TODO: Switch to v6 endpoint
|
|
41
|
+
async getCoreEvents(eventId: string): Promise<DriveEventsListWithStatus> {
|
|
42
|
+
// TODO: Switch to v6 endpoint?
|
|
38
43
|
const result = await this.apiService.get<GetCoreEventResponse>(`core/v5/events/${eventId}`);
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
+
// in core/v5/events, refresh is always all apps, value 255
|
|
45
|
+
const refresh = result.Refresh > 0;
|
|
46
|
+
const events: DriveEvent[] =
|
|
47
|
+
refresh || result.DriveShareRefresh?.Action === 2
|
|
48
|
+
? [
|
|
49
|
+
{
|
|
50
|
+
type: DriveEventType.SharedWithMeUpdated,
|
|
51
|
+
eventId: result.EventID,
|
|
52
|
+
treeEventScopeId: 'core',
|
|
53
|
+
},
|
|
54
|
+
]
|
|
55
|
+
: [];
|
|
44
56
|
|
|
45
57
|
return {
|
|
46
|
-
|
|
58
|
+
latestEventId: result.EventID,
|
|
47
59
|
more: result.More === 1,
|
|
48
60
|
refresh: result.Refresh === 1,
|
|
49
61
|
events,
|
|
@@ -51,35 +63,33 @@ export class EventsAPIService {
|
|
|
51
63
|
}
|
|
52
64
|
|
|
53
65
|
async getVolumeLatestEventId(volumeId: string): Promise<string> {
|
|
54
|
-
const result = await this.apiService.get<GetVolumeLatestEventResponse>(
|
|
66
|
+
const result = await this.apiService.get<GetVolumeLatestEventResponse>(
|
|
67
|
+
`drive/volumes/${volumeId}/events/latest`,
|
|
68
|
+
);
|
|
55
69
|
return result.EventID;
|
|
56
70
|
}
|
|
57
71
|
|
|
58
|
-
async getVolumeEvents(volumeId: string, eventId: string
|
|
59
|
-
const result = await this.apiService.get<
|
|
72
|
+
async getVolumeEvents(volumeId: string, eventId: string): Promise<DriveEventsListWithStatus> {
|
|
73
|
+
const result = await this.apiService.get<GetVolumeEventResponse>(
|
|
74
|
+
`drive/v2/volumes/${volumeId}/events/${eventId}`,
|
|
75
|
+
);
|
|
60
76
|
return {
|
|
61
|
-
|
|
77
|
+
latestEventId: result.EventID,
|
|
62
78
|
more: result.More,
|
|
63
79
|
refresh: result.Refresh,
|
|
64
|
-
events: result.Events.map((event):
|
|
80
|
+
events: result.Events.map((event): NodeEvent => {
|
|
65
81
|
const type = VOLUME_EVENT_TYPE_MAP[event.EventType];
|
|
66
82
|
const uids = {
|
|
67
83
|
nodeUid: makeNodeUid(volumeId, event.Link.LinkID),
|
|
68
84
|
parentNodeUid: makeNodeUid(volumeId, event.Link.ParentLinkID as string),
|
|
69
|
-
}
|
|
70
|
-
// VOLUME_EVENT_TYPE_MAP will never return this event type.
|
|
71
|
-
// It is here to satisfy the type checker. It is safe to do.
|
|
72
|
-
if (type === DriveEventType.ShareWithMeUpdated) {
|
|
73
|
-
return {
|
|
74
|
-
type,
|
|
75
|
-
};
|
|
76
|
-
}
|
|
85
|
+
};
|
|
77
86
|
return {
|
|
78
87
|
type,
|
|
79
88
|
...uids,
|
|
80
89
|
isTrashed: event.Link.IsTrashed,
|
|
81
90
|
isShared: event.Link.IsShared,
|
|
82
|
-
|
|
91
|
+
eventId: event.EventID,
|
|
92
|
+
treeEventScopeId: volumeId,
|
|
83
93
|
};
|
|
84
94
|
}),
|
|
85
95
|
};
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { getMockLogger } from '../../tests/logger';
|
|
2
|
+
import { EventsAPIService } from './apiService';
|
|
3
|
+
import { DriveEvent, DriveEventsListWithStatus, DriveEventType } from './interface';
|
|
4
|
+
import { CoreEventManager } from './coreEventManager';
|
|
5
|
+
|
|
6
|
+
describe('CoreEventManager', () => {
|
|
7
|
+
let mockApiService: jest.Mocked<EventsAPIService>;
|
|
8
|
+
let coreEventManager: CoreEventManager;
|
|
9
|
+
const mockLogger = getMockLogger();
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
// Reset mocks
|
|
13
|
+
jest.clearAllMocks();
|
|
14
|
+
|
|
15
|
+
mockApiService = {
|
|
16
|
+
getCoreLatestEventId: jest.fn(),
|
|
17
|
+
getCoreEvents: jest.fn(),
|
|
18
|
+
getVolumeLatestEventId: jest.fn(),
|
|
19
|
+
getVolumeEvents: jest.fn(),
|
|
20
|
+
} as unknown as jest.Mocked<EventsAPIService>;
|
|
21
|
+
|
|
22
|
+
coreEventManager = new CoreEventManager(mockLogger, mockApiService);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
describe('getLatestEventId', () => {
|
|
26
|
+
it('should return the latest event ID from API service', async () => {
|
|
27
|
+
const expectedEventId = 'event-123';
|
|
28
|
+
mockApiService.getCoreLatestEventId.mockResolvedValue(expectedEventId);
|
|
29
|
+
|
|
30
|
+
const result = await coreEventManager.getLatestEventId();
|
|
31
|
+
|
|
32
|
+
expect(result).toBe(expectedEventId);
|
|
33
|
+
expect(mockApiService.getCoreLatestEventId).toHaveBeenCalledTimes(1);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it('should handle API service errors', async () => {
|
|
37
|
+
const error = new Error('API error');
|
|
38
|
+
mockApiService.getCoreLatestEventId.mockRejectedValue(error);
|
|
39
|
+
|
|
40
|
+
await expect(coreEventManager.getLatestEventId()).rejects.toThrow('API error');
|
|
41
|
+
expect(mockApiService.getCoreLatestEventId).toHaveBeenCalledTimes(1);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
describe('getEvents', () => {
|
|
46
|
+
const eventId = 'event1';
|
|
47
|
+
const latestEventId = 'event2';
|
|
48
|
+
|
|
49
|
+
it('should yield ShareWithMeUpdated event when refresh is true', async () => {
|
|
50
|
+
const mockEvents: DriveEventsListWithStatus = {
|
|
51
|
+
latestEventId,
|
|
52
|
+
more: false,
|
|
53
|
+
refresh: true,
|
|
54
|
+
events: [],
|
|
55
|
+
};
|
|
56
|
+
mockApiService.getCoreEvents.mockResolvedValue(mockEvents);
|
|
57
|
+
|
|
58
|
+
const events = [];
|
|
59
|
+
for await (const event of coreEventManager.getEvents(eventId)) {
|
|
60
|
+
events.push(event);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
expect(events).toHaveLength(1);
|
|
64
|
+
expect(events[0]).toEqual({
|
|
65
|
+
type: DriveEventType.SharedWithMeUpdated,
|
|
66
|
+
treeEventScopeId: 'core',
|
|
67
|
+
eventId: latestEventId,
|
|
68
|
+
});
|
|
69
|
+
expect(mockApiService.getCoreEvents).toHaveBeenCalledWith(eventId);
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
it('should yield all events when there are actual events', async () => {
|
|
73
|
+
const mockEvent1: DriveEvent = {
|
|
74
|
+
type: DriveEventType.SharedWithMeUpdated,
|
|
75
|
+
eventId: 'event-1',
|
|
76
|
+
treeEventScopeId: 'core',
|
|
77
|
+
};
|
|
78
|
+
const mockEvent2: DriveEvent = {
|
|
79
|
+
type: DriveEventType.SharedWithMeUpdated,
|
|
80
|
+
eventId: 'event-2',
|
|
81
|
+
treeEventScopeId: 'core',
|
|
82
|
+
};
|
|
83
|
+
const mockEvents: DriveEventsListWithStatus = {
|
|
84
|
+
latestEventId,
|
|
85
|
+
more: false,
|
|
86
|
+
refresh: false,
|
|
87
|
+
events: [mockEvent1, mockEvent2],
|
|
88
|
+
};
|
|
89
|
+
mockApiService.getCoreEvents.mockResolvedValue(mockEvents);
|
|
90
|
+
|
|
91
|
+
const events = [];
|
|
92
|
+
for await (const event of coreEventManager.getEvents(eventId)) {
|
|
93
|
+
events.push(event);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
expect(events).toHaveLength(2);
|
|
97
|
+
expect(events[0]).toEqual(mockEvent1);
|
|
98
|
+
expect(events[1]).toEqual(mockEvent2);
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
});
|
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import { Logger } from
|
|
2
|
-
import { LoggerWithPrefix } from
|
|
3
|
-
import { EventsAPIService } from
|
|
4
|
-
import {
|
|
5
|
-
import { DriveEvent, DriveEventType } from "./interface";
|
|
6
|
-
import { EventManager } from "./eventManager";
|
|
1
|
+
import { Logger } from '../../interface';
|
|
2
|
+
import { LoggerWithPrefix } from '../../telemetry';
|
|
3
|
+
import { EventsAPIService } from './apiService';
|
|
4
|
+
import { DriveEvent, DriveEventType, EventManagerInterface } from './interface';
|
|
7
5
|
|
|
8
6
|
/**
|
|
9
7
|
* Combines API and event manager to provide a service for listening to
|
|
@@ -11,59 +9,39 @@ import { EventManager } from "./eventManager";
|
|
|
11
9
|
* At this moment, Drive listenes only to shares with me updates from core
|
|
12
10
|
* events. Such even indicates that user was invited to the new share or
|
|
13
11
|
* that user's membership was removed from existing one and lost access.
|
|
14
|
-
*
|
|
12
|
+
*
|
|
15
13
|
* The client might be already using own core events, thus this service
|
|
16
14
|
* is here only in case the client is not connected to the Proton services
|
|
17
15
|
* with own implementation.
|
|
18
16
|
*/
|
|
19
|
-
export class CoreEventManager {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
17
|
+
export class CoreEventManager implements EventManagerInterface<DriveEvent> {
|
|
18
|
+
constructor(
|
|
19
|
+
private logger: Logger,
|
|
20
|
+
private apiService: EventsAPIService,
|
|
21
|
+
) {
|
|
23
22
|
this.apiService = apiService;
|
|
24
23
|
|
|
25
|
-
this.
|
|
26
|
-
new LoggerWithPrefix(logger, `core`),
|
|
27
|
-
() => this.getLastEventId(),
|
|
28
|
-
(eventId) => this.apiService.getCoreEvents(eventId),
|
|
29
|
-
(lastEventId) => this.cache.setLastEventId('core', {
|
|
30
|
-
lastEventId,
|
|
31
|
-
pollingIntervalInSeconds: this.manager.pollingIntervalInSeconds,
|
|
32
|
-
isOwnVolume: false,
|
|
33
|
-
}),
|
|
34
|
-
);
|
|
24
|
+
this.logger = new LoggerWithPrefix(logger, `core`);
|
|
35
25
|
}
|
|
36
26
|
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
if (lastEventId) {
|
|
40
|
-
return lastEventId;
|
|
41
|
-
}
|
|
42
|
-
return this.apiService.getCoreLatestEventId();
|
|
27
|
+
async getLatestEventId(): Promise<string> {
|
|
28
|
+
return await this.apiService.getCoreLatestEventId();
|
|
43
29
|
}
|
|
44
30
|
|
|
45
|
-
async
|
|
46
|
-
await this.
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
31
|
+
async *getEvents(eventId: string): AsyncIterable<DriveEvent> {
|
|
32
|
+
const events = await this.apiService.getCoreEvents(eventId);
|
|
33
|
+
if (events.events.length === 0 && events.latestEventId !== eventId) {
|
|
34
|
+
yield {
|
|
35
|
+
type: DriveEventType.SharedWithMeUpdated,
|
|
36
|
+
treeEventScopeId: 'core',
|
|
37
|
+
eventId: events.latestEventId,
|
|
38
|
+
};
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
yield* events.events;
|
|
51
42
|
}
|
|
52
43
|
|
|
53
|
-
|
|
54
|
-
this.
|
|
55
|
-
if (events) {
|
|
56
|
-
await callback(events);
|
|
57
|
-
}
|
|
58
|
-
if (fullRefresh) {
|
|
59
|
-
// Because only updates about shares that are shared with me
|
|
60
|
-
// are listened to from core events, in the case of core full
|
|
61
|
-
// refresh, we don't have to refresh anything more than this
|
|
62
|
-
// one specific event.
|
|
63
|
-
await callback([{
|
|
64
|
-
type: DriveEventType.ShareWithMeUpdated,
|
|
65
|
-
}]);
|
|
66
|
-
}
|
|
67
|
-
});
|
|
44
|
+
getLogger(): Logger {
|
|
45
|
+
return this.logger;
|
|
68
46
|
}
|
|
69
47
|
}
|