@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,271 +1,65 @@
|
|
|
1
|
-
import { Logger
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { DecryptedNode } from "./interface";
|
|
5
|
-
import { NodesCache } from "./cache";
|
|
6
|
-
import { NodesAccess } from "./nodesAccess";
|
|
7
|
-
|
|
8
|
-
type Listeners = {
|
|
9
|
-
/**
|
|
10
|
-
* Condition for the listener to be notified about the event.
|
|
11
|
-
*
|
|
12
|
-
* The condition is a function that receives the event information
|
|
13
|
-
* and returns true if the listener should be notified about the
|
|
14
|
-
* event.
|
|
15
|
-
*/
|
|
16
|
-
condition: (nodeEventInfo: NodeEventInfo) => boolean,
|
|
17
|
-
callback: NodeEventCallback,
|
|
18
|
-
}[];
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Minimal information about the event that is used for listener
|
|
22
|
-
* condition. The information is used to determine if the listener
|
|
23
|
-
* should be notified about the event.
|
|
24
|
-
*
|
|
25
|
-
* This must come from the API response to volume events.
|
|
26
|
-
*/
|
|
27
|
-
type NodeEventInfo = {
|
|
28
|
-
parentNodeUid?: string,
|
|
29
|
-
isTrashed?: boolean,
|
|
30
|
-
}
|
|
1
|
+
import { Logger } from '../../interface';
|
|
2
|
+
import { DriveEvent, DriveEventType } from '../events';
|
|
3
|
+
import { NodesCache } from './cache';
|
|
31
4
|
|
|
32
5
|
/**
|
|
33
|
-
* Provides
|
|
34
|
-
*
|
|
6
|
+
* Provides internal event handling.
|
|
7
|
+
*
|
|
35
8
|
* The service is responsible for handling events regarding node metadata
|
|
36
|
-
* from the DriveEventsService
|
|
37
|
-
* for the user to listen to updates of specific group of nodes, such as
|
|
38
|
-
* any update for trashed nodes.
|
|
9
|
+
* from the DriveEventsService.
|
|
39
10
|
*/
|
|
40
|
-
export class
|
|
41
|
-
|
|
11
|
+
export class NodesEventsHandler {
|
|
12
|
+
constructor(
|
|
13
|
+
private logger: Logger,
|
|
14
|
+
private cache: NodesCache,
|
|
15
|
+
) {}
|
|
42
16
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
events.addListener(async (events, fullRefreshVolumeId) => {
|
|
49
|
-
if (fullRefreshVolumeId) {
|
|
50
|
-
await cache.setNodesStaleFromVolume(fullRefreshVolumeId);
|
|
17
|
+
async updateNodesCacheOnEvent(event: DriveEvent): Promise<void> {
|
|
18
|
+
try {
|
|
19
|
+
if (event.type === DriveEventType.TreeRefresh) {
|
|
20
|
+
await this.cache.setNodesStaleFromVolume(event.treeEventScopeId);
|
|
51
21
|
return;
|
|
52
22
|
}
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
await updateCacheByEvent(logger, event, cache);
|
|
57
|
-
} catch (error: unknown) {
|
|
58
|
-
logger.error(`Failed to update cache`, error);
|
|
59
|
-
}
|
|
60
|
-
try {
|
|
61
|
-
await notifyListenersByEvent(logger, event, this.listeners, cache, nodesAccess);
|
|
62
|
-
} catch (error: unknown) {
|
|
63
|
-
logger.error(`Failed to notifiy listeners`, error);
|
|
64
|
-
}
|
|
65
|
-
// Delete must come last as it will remove the node from the cache
|
|
66
|
-
// and we need to first know local status of the node to properly
|
|
67
|
-
// notify the listeners.
|
|
68
|
-
await deleteFromCacheByEvent(logger, event, cache);
|
|
23
|
+
if (event.type === DriveEventType.TreeRemove) {
|
|
24
|
+
await this.cache.removeVolume(event.treeEventScopeId);
|
|
25
|
+
return;
|
|
69
26
|
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
this.listeners = this.listeners.filter(listener => listener.callback !== callback);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
async nodeCreated(node: DecryptedNode): Promise<void> {
|
|
88
|
-
await this.cache.setNode(node);
|
|
89
|
-
void this.notifyListenersByNode(node, DriveEventType.NodeCreated);
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
async nodeUpdated(partialNode: { uid: string } & Partial<DecryptedNode>): Promise<void> {
|
|
93
|
-
const originalNode = await this.cache.getNode(partialNode.uid);
|
|
94
|
-
const updatedNode = {
|
|
95
|
-
...originalNode,
|
|
96
|
-
...partialNode,
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
await this.cache.setNode(updatedNode);
|
|
100
|
-
void this.notifyListenersByNode(updatedNode, DriveEventType.NodeUpdated);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
async nodesDeleted(nodeUids: string[]): Promise<void> {
|
|
104
|
-
try {
|
|
105
|
-
for await (const originalNode of this.cache.iterateNodes(nodeUids)) {
|
|
106
|
-
if (originalNode.ok) {
|
|
107
|
-
void this.notifyListenersByNode(originalNode.node, DriveEventType.NodeDeleted);
|
|
27
|
+
if (event.type === DriveEventType.NodeDeleted) {
|
|
28
|
+
await this.cache.removeNodes([event.nodeUid]);
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
if (event.type === DriveEventType.NodeCreated) {
|
|
32
|
+
// FIXME Add it to the parent listing even if it's not cached
|
|
33
|
+
// so it doesn't need to refetch all children
|
|
34
|
+
|
|
35
|
+
// We do not have partial nodes in the cache, so we don't
|
|
36
|
+
// add it. If new node is not added, we need to reset the
|
|
37
|
+
// children loaded flag to force refetch when requested.
|
|
38
|
+
if (event.parentNodeUid) {
|
|
39
|
+
await this.cache.resetFolderChildrenLoaded(event.parentNodeUid);
|
|
108
40
|
}
|
|
41
|
+
return;
|
|
109
42
|
}
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
parentNodeUid: node.parentUid,
|
|
120
|
-
isOwnVolume: true,
|
|
121
|
-
isTrashed: !!node.trashTime,
|
|
122
|
-
isShared: node.isShared,
|
|
123
|
-
};
|
|
124
|
-
await notifyListenersByEvent(this.logger, event, this.listeners, this.cache, this.nodesAccess);
|
|
125
|
-
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
/**
|
|
130
|
-
* For given event, update the cache accordingly.
|
|
131
|
-
*
|
|
132
|
-
* The function is responsible for updating the cache based on the
|
|
133
|
-
* event received from the DriveEventsService. The cache metadata
|
|
134
|
-
* are not updated, only the nodes are marked as stale to be
|
|
135
|
-
* fetched and decrypted again when requested by the client.
|
|
136
|
-
*
|
|
137
|
-
* If the node is not found in the cache, the event is silently
|
|
138
|
-
* skipped as the node will be fetched and decrypted when requested
|
|
139
|
-
* by the client.
|
|
140
|
-
*
|
|
141
|
-
* If the node cannot be updated in the cache, the node is removed
|
|
142
|
-
* from the cache to not block the client. If the node is not possible
|
|
143
|
-
* to remove, the function throws an error.
|
|
144
|
-
*
|
|
145
|
-
* @throws Only if the node is not possible to remove from the cache.
|
|
146
|
-
*/
|
|
147
|
-
export async function updateCacheByEvent(logger: Logger, event: DriveEvent, cache: NodesCache) {
|
|
148
|
-
// NodeCreated event is ignored as we do not want to fetch and
|
|
149
|
-
// decrypt the node immediately. The node will be fetched and
|
|
150
|
-
// decrypted when requested by the client.
|
|
151
|
-
if (event.type === DriveEventType.NodeCreated) {
|
|
152
|
-
// We do not have partial nodes in the cache, so we don't
|
|
153
|
-
// add it. If new node is not added, we need to reset the
|
|
154
|
-
// children loaded flag to force refetch when requested.
|
|
155
|
-
if (event.parentNodeUid) {
|
|
156
|
-
await cache.resetFolderChildrenLoaded(event.parentNodeUid);
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
if (event.type === DriveEventType.NodeUpdated || event.type === DriveEventType.NodeUpdatedMetadata) {
|
|
160
|
-
let node;
|
|
161
|
-
// getNode can fail if the node is not found or if it is
|
|
162
|
-
// corrupted. In later case, it will be automatically
|
|
163
|
-
// removed from cache. In both cases, lets skip the event
|
|
164
|
-
// silently as once requested by client, the node will
|
|
165
|
-
// be cached again.
|
|
166
|
-
try {
|
|
167
|
-
node = await cache.getNode(event.nodeUid);
|
|
168
|
-
} catch (error: unknown) {
|
|
169
|
-
logger.debug(`Skipping node update event (node not in the cache): ${error}`);
|
|
170
|
-
}
|
|
171
|
-
if (node) {
|
|
172
|
-
node.isStale = true;
|
|
173
|
-
// We need to update the parentUid as the node might have
|
|
174
|
-
// been moved to another parent. This is important for
|
|
175
|
-
// children iteration.
|
|
176
|
-
node.parentUid = event.parentNodeUid;
|
|
177
|
-
try {
|
|
178
|
-
await cache.setNode(node);
|
|
179
|
-
} catch (setNodeError: unknown) {
|
|
180
|
-
logger.error(`Skipping node update event (failed to update)`, setNodeError);
|
|
181
|
-
// If updating node in the cache is failing, lets remove it
|
|
182
|
-
// to not block the whole client. If the node is not possible
|
|
183
|
-
// to remove, lets throw at this point as cache is in very
|
|
184
|
-
// bad state by this point and the rest of the code would start
|
|
185
|
-
// to break randomly.
|
|
186
|
-
try {
|
|
187
|
-
await cache.removeNodes([event.nodeUid]);
|
|
188
|
-
} catch (removeNodeError: unknown) {
|
|
189
|
-
logger.error(`Skipping node update event (failed to remove after failed update)`, removeNodeError);
|
|
190
|
-
// removeNodeError is automatic correction algorithm.
|
|
191
|
-
// If that fails, lets throw the original error as that
|
|
192
|
-
// is the real problem.
|
|
193
|
-
throw setNodeError;
|
|
43
|
+
if (event.type === DriveEventType.NodeUpdated) {
|
|
44
|
+
const node = await this.cache.getNode(event.nodeUid);
|
|
45
|
+
node.isStale = true;
|
|
46
|
+
node.parentUid = event.parentNodeUid;
|
|
47
|
+
node.isShared = event.isShared;
|
|
48
|
+
if (event.isTrashed) {
|
|
49
|
+
node.trashTime ??= new Date();
|
|
50
|
+
} else {
|
|
51
|
+
node.trashTime = undefined;
|
|
194
52
|
}
|
|
53
|
+
await this.cache.setNode(node);
|
|
195
54
|
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
/**
|
|
201
|
-
* For given event, delete the node from the cache if it is
|
|
202
|
-
* deleted.
|
|
203
|
-
*/
|
|
204
|
-
export async function deleteFromCacheByEvent(logger: Logger, event: DriveEvent, cache: NodesCache) {
|
|
205
|
-
if (event.type === DriveEventType.NodeDeleted) {
|
|
206
|
-
// removeNodes can fail removing children.
|
|
207
|
-
// We do not want to stop processing other events in such
|
|
208
|
-
// a case. Lets log the error and continue.
|
|
209
|
-
try {
|
|
210
|
-
await cache.removeNodes([event.nodeUid]);
|
|
211
55
|
} catch (error: unknown) {
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
/**
|
|
218
|
-
* For given event, notify the listeners accordingly.
|
|
219
|
-
*
|
|
220
|
-
* The function is responsible for notifying the listeners about the
|
|
221
|
-
* event received from the DriveEventsService. The listeners are
|
|
222
|
-
* connected with events based on the condition, such as parent node
|
|
223
|
-
* uid for listening to children updates.
|
|
224
|
-
*
|
|
225
|
-
* The function is responsible for fetching and decrypting the latest
|
|
226
|
-
* version of the node metadata. If the node is not found, the event
|
|
227
|
-
* is silently skipped as the node will be fetched and decrypted when
|
|
228
|
-
* requested by the client.
|
|
229
|
-
*
|
|
230
|
-
* @throws Only if the client's callback throws.
|
|
231
|
-
*/
|
|
232
|
-
export async function notifyListenersByEvent(logger: Logger, event: DriveEvent, listeners: Listeners, cache: NodesCache, nodesAccess: NodesAccess) {
|
|
233
|
-
if (event.type === DriveEventType.ShareWithMeUpdated) {
|
|
234
|
-
return;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
const subscribedListeners = listeners.filter(({ condition }) => condition(event));
|
|
238
|
-
const eventMatchingCondition = subscribedListeners.length > 0;
|
|
239
|
-
|
|
240
|
-
if ([DriveEventType.NodeCreated, DriveEventType.NodeUpdated, DriveEventType.NodeUpdatedMetadata].includes(event.type) && eventMatchingCondition) {
|
|
241
|
-
if (subscribedListeners.length) {
|
|
242
|
-
let node;
|
|
243
|
-
try {
|
|
244
|
-
node = await nodesAccess.getNode(event.nodeUid);
|
|
245
|
-
} catch (error: unknown) {
|
|
246
|
-
logger.error(`Skipping node update event to listener`, error);
|
|
247
|
-
return;
|
|
56
|
+
if (error instanceof Error) {
|
|
57
|
+
// FIXME throw CacheMissException error and catch it
|
|
58
|
+
if (error.message === 'Entity not found') {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
248
61
|
}
|
|
249
|
-
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
if (
|
|
254
|
-
((event.type === DriveEventType.NodeUpdated || event.type === DriveEventType.NodeUpdatedMetadata) && !eventMatchingCondition)
|
|
255
|
-
|| event.type === DriveEventType.NodeDeleted
|
|
256
|
-
) {
|
|
257
|
-
let node: DecryptedNode;
|
|
258
|
-
try {
|
|
259
|
-
node = await cache.getNode(event.nodeUid);
|
|
260
|
-
} catch {}
|
|
261
|
-
|
|
262
|
-
const subscribedListeners = listeners.filter(({ condition }) => condition({
|
|
263
|
-
parentNodeUid: node?.parentUid,
|
|
264
|
-
isTrashed: !!node?.trashTime || false,
|
|
265
|
-
}));
|
|
266
|
-
|
|
267
|
-
if (subscribedListeners.length) {
|
|
268
|
-
subscribedListeners.forEach(({ callback }) => callback({ type: 'remove', uid: event.nodeUid }));
|
|
62
|
+
this.logger.error(`Failed to update node cache for event: ${event.eventId}`, error);
|
|
269
63
|
}
|
|
270
64
|
}
|
|
271
65
|
}
|
|
@@ -1,5 +1,12 @@
|
|
|
1
|
-
import { getMockLogger } from
|
|
2
|
-
import {
|
|
1
|
+
import { getMockLogger } from '../../tests/logger';
|
|
2
|
+
import {
|
|
3
|
+
FolderExtendedAttributes,
|
|
4
|
+
FileExtendedAttributesParsed,
|
|
5
|
+
generateFolderExtendedAttributes,
|
|
6
|
+
generateFileExtendedAttributes,
|
|
7
|
+
parseFolderExtendedAttributes,
|
|
8
|
+
parseFileExtendedAttributes,
|
|
9
|
+
} from './extendedAttributes';
|
|
3
10
|
|
|
4
11
|
describe('extended attrbiutes', () => {
|
|
5
12
|
describe('should generate folder attributes', () => {
|
|
@@ -11,7 +18,7 @@ describe('extended attrbiutes', () => {
|
|
|
11
18
|
it(`should generate ${input}`, () => {
|
|
12
19
|
const output = generateFolderExtendedAttributes(input);
|
|
13
20
|
expect(output).toBe(expectedAttributes);
|
|
14
|
-
})
|
|
21
|
+
});
|
|
15
22
|
});
|
|
16
23
|
});
|
|
17
24
|
|
|
@@ -26,46 +33,43 @@ describe('extended attrbiutes', () => {
|
|
|
26
33
|
claimedModificationTime: new Date(1234567890000),
|
|
27
34
|
},
|
|
28
35
|
],
|
|
29
|
-
[
|
|
30
|
-
'{"Common": {"ModificationTime": "aa"}}',
|
|
31
|
-
{},
|
|
32
|
-
],
|
|
36
|
+
['{"Common": {"ModificationTime": "aa"}}', {}],
|
|
33
37
|
[
|
|
34
38
|
'{"Common": {"ModificationTime": "2009-02-13T23:31:30+0000", "Size": 123}}',
|
|
35
39
|
{
|
|
36
40
|
claimedModificationTime: new Date(1234567890000),
|
|
37
41
|
},
|
|
38
42
|
],
|
|
39
|
-
[
|
|
40
|
-
'{"Common": {"Whatever": 123}}',
|
|
41
|
-
{},
|
|
42
|
-
],
|
|
43
|
+
['{"Common": {"Whatever": 123}}', {}],
|
|
43
44
|
];
|
|
44
45
|
testCases.forEach(([input, expectedAttributes]) => {
|
|
45
46
|
it(`should parse ${input}`, () => {
|
|
46
47
|
const output = parseFolderExtendedAttributes(getMockLogger(), input);
|
|
47
48
|
expect(output).toMatchObject(expectedAttributes);
|
|
48
|
-
})
|
|
49
|
+
});
|
|
49
50
|
});
|
|
50
51
|
});
|
|
51
52
|
|
|
52
53
|
describe('should generate file attributes', () => {
|
|
53
54
|
const testCases: [object, string | undefined][] = [
|
|
54
55
|
[{}, undefined],
|
|
55
|
-
[
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
[{
|
|
60
|
-
[{
|
|
61
|
-
[{
|
|
62
|
-
[{
|
|
56
|
+
[
|
|
57
|
+
{ modificationTime: new Date(1234567890000) },
|
|
58
|
+
'{"Common":{"ModificationTime":"2009-02-13T23:31:30.000Z"}}',
|
|
59
|
+
],
|
|
60
|
+
[{ size: undefined }, undefined],
|
|
61
|
+
[{ size: 0 }, '{"Common":{"Size":0}}'],
|
|
62
|
+
[{ size: 1234 }, '{"Common":{"Size":1234}}'],
|
|
63
|
+
[{ blockSizes: [] }, undefined],
|
|
64
|
+
[{ blockSizes: [4, 4, 4, 2] }, '{"Common":{"BlockSizes":[4,4,4,2]}}'],
|
|
65
|
+
[{ digests: {} }, undefined],
|
|
66
|
+
[{ digests: { sha1: 'abcdef' } }, '{"Common":{"Digests":{"SHA1":"abcdef"}}}'],
|
|
63
67
|
[
|
|
64
68
|
{
|
|
65
69
|
modificationTime: new Date(1234567890000),
|
|
66
70
|
size: 1234,
|
|
67
71
|
blockSizes: [4, 4, 4, 2],
|
|
68
|
-
digests: {sha1: 'abcdef'},
|
|
72
|
+
digests: { sha1: 'abcdef' },
|
|
69
73
|
},
|
|
70
74
|
'{"Common":{"ModificationTime":"2009-02-13T23:31:30.000Z","Size":1234,"BlockSizes":[4,4,4,2],"Digests":{"SHA1":"abcdef"}}}',
|
|
71
75
|
],
|
|
@@ -74,7 +78,7 @@ describe('extended attrbiutes', () => {
|
|
|
74
78
|
it(`should generate ${input}`, () => {
|
|
75
79
|
const output = generateFileExtendedAttributes(input);
|
|
76
80
|
expect(output).toBe(expectedAttributes);
|
|
77
|
-
})
|
|
81
|
+
});
|
|
78
82
|
});
|
|
79
83
|
});
|
|
80
84
|
|
|
@@ -151,7 +155,7 @@ describe('extended attrbiutes', () => {
|
|
|
151
155
|
{
|
|
152
156
|
claimedModificationTime: undefined,
|
|
153
157
|
claimedSize: undefined,
|
|
154
|
-
claimedDigests: {sha1:
|
|
158
|
+
claimedDigests: { sha1: 'abcdef' },
|
|
155
159
|
claimedAdditionalMetadata: undefined,
|
|
156
160
|
},
|
|
157
161
|
],
|
|
@@ -171,7 +175,7 @@ describe('extended attrbiutes', () => {
|
|
|
171
175
|
it(`should parse ${input}`, () => {
|
|
172
176
|
const output = parseFileExtendedAttributes(getMockLogger(), input);
|
|
173
177
|
expect(output).toMatchObject(expectedAttributes);
|
|
174
|
-
})
|
|
178
|
+
});
|
|
175
179
|
});
|
|
176
180
|
});
|
|
177
181
|
});
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Logger } from
|
|
1
|
+
import { Logger } from '../../interface';
|
|
2
2
|
|
|
3
3
|
interface FolderExtendedAttributesSchema {
|
|
4
4
|
Common?: {
|
|
@@ -38,16 +38,16 @@ interface FileExtendedAttributesSchema {
|
|
|
38
38
|
}
|
|
39
39
|
|
|
40
40
|
export interface FolderExtendedAttributes {
|
|
41
|
-
claimedModificationTime?: Date
|
|
41
|
+
claimedModificationTime?: Date;
|
|
42
42
|
}
|
|
43
43
|
|
|
44
44
|
export interface FileExtendedAttributesParsed {
|
|
45
|
-
claimedSize?: number
|
|
46
|
-
claimedModificationTime?: Date
|
|
45
|
+
claimedSize?: number;
|
|
46
|
+
claimedModificationTime?: Date;
|
|
47
47
|
claimedDigests?: {
|
|
48
|
-
sha1?: string
|
|
49
|
-
}
|
|
50
|
-
claimedAdditionalMetadata?: object
|
|
48
|
+
sha1?: string;
|
|
49
|
+
};
|
|
50
|
+
claimedAdditionalMetadata?: object;
|
|
51
51
|
}
|
|
52
52
|
|
|
53
53
|
export function generateFolderExtendedAttributes(claimedModificationTime?: Date): string | undefined {
|
|
@@ -83,12 +83,12 @@ export function parseFolderExtendedAttributes(logger: Logger, extendedAttributes
|
|
|
83
83
|
}
|
|
84
84
|
|
|
85
85
|
export function generateFileExtendedAttributes(options: {
|
|
86
|
-
modificationTime?: Date
|
|
87
|
-
size?: number
|
|
88
|
-
blockSizes?: number[]
|
|
86
|
+
modificationTime?: Date;
|
|
87
|
+
size?: number;
|
|
88
|
+
blockSizes?: number[];
|
|
89
89
|
digests?: {
|
|
90
|
-
sha1?: string
|
|
91
|
-
}
|
|
90
|
+
sha1?: string;
|
|
91
|
+
};
|
|
92
92
|
}): string | undefined {
|
|
93
93
|
const commonAttributes: FileExtendedAttributesSchema['Common'] = {};
|
|
94
94
|
if (options.modificationTime) {
|
|
@@ -115,7 +115,7 @@ export function generateFileExtendedAttributes(options: {
|
|
|
115
115
|
|
|
116
116
|
export function parseFileExtendedAttributes(logger: Logger, extendedAttributes?: string): FileExtendedAttributesParsed {
|
|
117
117
|
if (!extendedAttributes) {
|
|
118
|
-
return {}
|
|
118
|
+
return {};
|
|
119
119
|
}
|
|
120
120
|
|
|
121
121
|
try {
|
|
@@ -128,7 +128,9 @@ export function parseFileExtendedAttributes(logger: Logger, extendedAttributes?:
|
|
|
128
128
|
claimedSize: parseSize(logger, parsed),
|
|
129
129
|
claimedModificationTime: parseModificationTime(logger, parsed),
|
|
130
130
|
claimedDigests: parseDigests(logger, parsed),
|
|
131
|
-
claimedAdditionalMetadata: Object.keys(claimedAdditionalMetadata).length
|
|
131
|
+
claimedAdditionalMetadata: Object.keys(claimedAdditionalMetadata).length
|
|
132
|
+
? claimedAdditionalMetadata
|
|
133
|
+
: undefined,
|
|
132
134
|
};
|
|
133
135
|
} catch (error: unknown) {
|
|
134
136
|
logger.error(`Failed to parse extended attributes`, error);
|
|
@@ -148,7 +150,10 @@ function parseSize(logger: Logger, xattr?: FileExtendedAttributesSchema): number
|
|
|
148
150
|
return size;
|
|
149
151
|
}
|
|
150
152
|
|
|
151
|
-
function parseModificationTime(
|
|
153
|
+
function parseModificationTime(
|
|
154
|
+
logger: Logger,
|
|
155
|
+
xattr?: FolderExtendedAttributesSchema | FolderExtendedAttributesSchema,
|
|
156
|
+
): Date | undefined {
|
|
152
157
|
const modificationTime = xattr?.Common?.ModificationTime;
|
|
153
158
|
if (modificationTime === undefined) {
|
|
154
159
|
return undefined;
|