@azure/storage-file-share 12.27.0 → 12.28.0-beta.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/README.md +105 -155
- package/dist/browser/AccountSASPermissions.d.ts +61 -0
- package/dist/browser/AccountSASPermissions.d.ts.map +1 -0
- package/dist/browser/AccountSASPermissions.js.map +1 -0
- package/dist/browser/AccountSASResourceTypes.d.ts +38 -0
- package/dist/browser/AccountSASResourceTypes.d.ts.map +1 -0
- package/dist/browser/AccountSASResourceTypes.js.map +1 -0
- package/dist/browser/AccountSASServices.d.ts +40 -0
- package/dist/browser/AccountSASServices.d.ts.map +1 -0
- package/dist/browser/AccountSASServices.js.map +1 -0
- package/dist/browser/AccountSASSignatureValues.d.ts +73 -0
- package/dist/browser/AccountSASSignatureValues.d.ts.map +1 -0
- package/dist/browser/AccountSASSignatureValues.js +71 -0
- package/dist/browser/AccountSASSignatureValues.js.map +1 -0
- package/dist/browser/Clients.d.ts +3114 -0
- package/dist/browser/Clients.d.ts.map +1 -0
- package/dist/browser/Clients.js +2882 -0
- package/dist/browser/Clients.js.map +1 -0
- package/dist/browser/FileDownloadResponse-browser.d.mts.map +1 -0
- package/dist/browser/FileDownloadResponse-browser.mjs.map +1 -0
- package/dist/browser/FileDownloadResponse.d.ts +2 -0
- package/dist/browser/FileDownloadResponse.js +7 -0
- package/dist/browser/FileSASPermissions.d.ts +42 -0
- package/dist/browser/FileSASPermissions.d.ts.map +1 -0
- package/dist/browser/FileSASPermissions.js.map +1 -0
- package/dist/browser/FileSASSignatureValues.d.ts +95 -0
- package/dist/browser/FileSASSignatureValues.d.ts.map +1 -0
- package/dist/browser/FileSASSignatureValues.js +84 -0
- package/dist/browser/FileSASSignatureValues.js.map +1 -0
- package/dist/browser/FileSystemAttributes.d.ts +63 -0
- package/dist/browser/FileSystemAttributes.d.ts.map +1 -0
- package/dist/browser/FileSystemAttributes.js.map +1 -0
- package/dist/browser/Pipeline.d.ts +142 -0
- package/dist/browser/Pipeline.d.ts.map +1 -0
- package/dist/browser/Pipeline.js +261 -0
- package/dist/browser/Pipeline.js.map +1 -0
- package/dist/browser/Range.d.ts +25 -0
- package/dist/browser/Range.d.ts.map +1 -0
- package/dist/browser/Range.js.map +1 -0
- package/dist/browser/SASQueryParameters.d.ts +136 -0
- package/dist/browser/SASQueryParameters.d.ts.map +1 -0
- package/dist/browser/SASQueryParameters.js +177 -0
- package/dist/browser/SASQueryParameters.js.map +1 -0
- package/dist/browser/SasIPRange.d.ts +25 -0
- package/dist/browser/SasIPRange.d.ts.map +1 -0
- package/dist/browser/SasIPRange.js.map +1 -0
- package/dist/browser/ShareClientInternal.d.ts +12 -0
- package/dist/browser/ShareClientInternal.d.ts.map +1 -0
- package/dist/browser/ShareClientInternal.js +16 -0
- package/dist/browser/ShareClientInternal.js.map +1 -0
- package/dist/browser/ShareSASPermissions.d.ts +46 -0
- package/dist/browser/ShareSASPermissions.d.ts.map +1 -0
- package/dist/browser/ShareSASPermissions.js.map +1 -0
- package/dist/browser/ShareServiceClient.d.ts +427 -0
- package/dist/browser/ShareServiceClient.d.ts.map +1 -0
- package/dist/browser/ShareServiceClient.js +475 -0
- package/dist/browser/ShareServiceClient.js.map +1 -0
- package/dist/browser/StorageClient.d.ts +47 -0
- package/dist/browser/StorageClient.d.ts.map +1 -0
- package/dist/browser/StorageClient.js +30 -0
- package/dist/browser/StorageClient.js.map +1 -0
- package/dist/browser/StorageContextClient.d.ts +9 -0
- package/dist/browser/StorageContextClient.d.ts.map +1 -0
- package/dist/browser/StorageContextClient.js +18 -0
- package/dist/browser/StorageContextClient.js.map +1 -0
- package/dist/browser/StorageRetryPolicyFactory.d.ts +56 -0
- package/dist/browser/StorageRetryPolicyFactory.d.ts.map +1 -0
- package/dist/browser/StorageRetryPolicyFactory.js +26 -0
- package/dist/browser/StorageRetryPolicyFactory.js.map +1 -0
- package/dist/browser/generated/src/index.d.ts +4 -0
- package/dist/browser/generated/src/index.d.ts.map +1 -0
- package/dist/browser/generated/src/index.js +11 -0
- package/dist/browser/generated/src/index.js.map +1 -0
- package/dist/browser/generated/src/models/index.d.ts +2881 -0
- package/dist/browser/generated/src/models/index.d.ts.map +1 -0
- package/dist/browser/generated/src/models/index.js.map +1 -0
- package/dist/browser/generated/src/models/mappers.d.ts +128 -0
- package/dist/browser/generated/src/models/mappers.d.ts.map +1 -0
- package/dist/browser/generated/src/models/mappers.js.map +1 -0
- package/dist/browser/generated/src/models/parameters.d.ts +128 -0
- package/dist/browser/generated/src/models/parameters.d.ts.map +1 -0
- package/dist/browser/generated/src/models/parameters.js +1364 -0
- package/dist/browser/generated/src/models/parameters.js.map +1 -0
- package/dist/browser/generated/src/operations/directory.d.ts +65 -0
- package/dist/browser/generated/src/operations/directory.d.ts.map +1 -0
- package/dist/browser/generated/src/operations/directory.js +378 -0
- package/dist/browser/generated/src/operations/directory.js.map +1 -0
- package/dist/browser/generated/src/operations/file.d.ts +162 -0
- package/dist/browser/generated/src/operations/file.d.ts.map +1 -0
- package/dist/browser/generated/src/operations/file.js +866 -0
- package/dist/browser/generated/src/operations/file.js.map +1 -0
- package/dist/browser/generated/src/operations/index.d.ts +5 -0
- package/dist/browser/generated/src/operations/index.d.ts.map +1 -0
- package/dist/browser/generated/src/operations/index.js +12 -0
- package/dist/browser/generated/src/operations/index.js.map +1 -0
- package/dist/browser/generated/src/operations/service.d.ts +32 -0
- package/dist/browser/generated/src/operations/service.d.ts.map +1 -0
- package/dist/browser/generated/src/operations/service.js +135 -0
- package/dist/browser/generated/src/operations/service.js.map +1 -0
- package/dist/browser/generated/src/operations/share.d.ts +111 -0
- package/dist/browser/generated/src/operations/share.d.ts.map +1 -0
- package/dist/browser/generated/src/operations/share.js +671 -0
- package/dist/browser/generated/src/operations/share.js.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/directory.d.ts +57 -0
- package/dist/browser/generated/src/operationsInterfaces/directory.d.ts.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/directory.js.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/file.d.ts +154 -0
- package/dist/browser/generated/src/operationsInterfaces/file.d.ts.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/file.js.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/index.d.ts +5 -0
- package/dist/browser/generated/src/operationsInterfaces/index.d.ts.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/index.js +12 -0
- package/dist/browser/generated/src/operationsInterfaces/index.js.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/service.d.ts +24 -0
- package/dist/browser/generated/src/operationsInterfaces/service.d.ts.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/service.js.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/share.d.ts +103 -0
- package/dist/browser/generated/src/operationsInterfaces/share.d.ts.map +1 -0
- package/dist/browser/generated/src/operationsInterfaces/share.js.map +1 -0
- package/dist/browser/generated/src/storageClient.d.ts +20 -0
- package/dist/browser/generated/src/storageClient.d.ts.map +1 -0
- package/dist/browser/generated/src/storageClient.js +48 -0
- package/dist/browser/generated/src/storageClient.js.map +1 -0
- package/dist/browser/generatedModels.d.ts +492 -0
- package/dist/browser/generatedModels.d.ts.map +1 -0
- package/dist/browser/generatedModels.js.map +1 -0
- package/dist/browser/index-browser.d.mts.map +1 -0
- package/dist/browser/index-browser.mjs.map +1 -0
- package/dist/browser/index.d.ts +22 -0
- package/dist/browser/index.js +19 -0
- package/dist/browser/log.d.ts +5 -0
- package/dist/browser/log.d.ts.map +1 -0
- package/dist/browser/log.js.map +1 -0
- package/dist/browser/models.d.ts +373 -0
- package/dist/browser/models.d.ts.map +1 -0
- package/dist/browser/models.js +94 -0
- package/dist/browser/models.js.map +1 -0
- package/dist/browser/package.json +3 -0
- package/dist/browser/policies/StorageRetryPolicy.d.ts +75 -0
- package/dist/browser/policies/StorageRetryPolicy.d.ts.map +1 -0
- package/dist/browser/policies/StorageRetryPolicy.js +220 -0
- package/dist/browser/policies/StorageRetryPolicy.js.map +1 -0
- package/dist/browser/policies/StorageRetryPolicyV2.d.ts +24 -0
- package/dist/browser/policies/StorageRetryPolicyV2.d.ts.map +1 -0
- package/dist/browser/policies/StorageRetryPolicyV2.js +176 -0
- package/dist/browser/policies/StorageRetryPolicyV2.js.map +1 -0
- package/dist/browser/utils/Batch.d.ts +68 -0
- package/dist/browser/utils/Batch.d.ts.map +1 -0
- package/dist/browser/utils/Batch.js.map +1 -0
- package/dist/browser/utils/BufferScheduler.d.ts +157 -0
- package/dist/browser/utils/BufferScheduler.d.ts.map +1 -0
- package/dist/browser/utils/BufferScheduler.js.map +1 -0
- package/dist/browser/utils/RetriableReadableStream.d.ts +58 -0
- package/dist/browser/utils/RetriableReadableStream.d.ts.map +1 -0
- package/dist/browser/utils/RetriableReadableStream.js +119 -0
- package/dist/browser/utils/RetriableReadableStream.js.map +1 -0
- package/dist/browser/utils/constants.d.ts +55 -0
- package/dist/browser/utils/constants.d.ts.map +1 -0
- package/dist/browser/utils/constants.js +162 -0
- package/dist/browser/utils/constants.js.map +1 -0
- package/dist/browser/utils/tracing.d.ts +6 -0
- package/dist/browser/utils/tracing.d.ts.map +1 -0
- package/dist/browser/utils/tracing.js +14 -0
- package/dist/browser/utils/tracing.js.map +1 -0
- package/dist/browser/utils/utils-browser.d.mts.map +1 -0
- package/dist/browser/utils/utils-browser.mjs.map +1 -0
- package/dist/browser/utils/utils.common.d.ts +304 -0
- package/dist/browser/utils/utils.common.d.ts.map +1 -0
- package/dist/browser/utils/utils.common.js +778 -0
- package/dist/browser/utils/utils.common.js.map +1 -0
- package/dist/browser/utils/utils.d.ts +5 -0
- package/dist/browser/utils/utils.js +15 -0
- package/dist/commonjs/AccountSASPermissions.d.ts +61 -0
- package/dist/commonjs/AccountSASPermissions.d.ts.map +1 -0
- package/dist/commonjs/AccountSASPermissions.js +132 -0
- package/dist/commonjs/AccountSASPermissions.js.map +1 -0
- package/dist/commonjs/AccountSASResourceTypes.d.ts +38 -0
- package/dist/commonjs/AccountSASResourceTypes.d.ts.map +1 -0
- package/dist/commonjs/AccountSASResourceTypes.js +76 -0
- package/dist/commonjs/AccountSASResourceTypes.js.map +1 -0
- package/dist/commonjs/AccountSASServices.d.ts +40 -0
- package/dist/commonjs/AccountSASServices.d.ts.map +1 -0
- package/dist/commonjs/AccountSASServices.js +84 -0
- package/dist/commonjs/AccountSASServices.js.map +1 -0
- package/dist/commonjs/AccountSASSignatureValues.d.ts +73 -0
- package/dist/commonjs/AccountSASSignatureValues.d.ts.map +1 -0
- package/dist/commonjs/AccountSASSignatureValues.js +75 -0
- package/dist/commonjs/AccountSASSignatureValues.js.map +1 -0
- package/dist/commonjs/Clients.d.ts +3114 -0
- package/dist/commonjs/Clients.d.ts.map +1 -0
- package/dist/commonjs/Clients.js +2889 -0
- package/dist/commonjs/Clients.js.map +1 -0
- package/dist/commonjs/FileDownloadResponse.d.ts +291 -0
- package/dist/commonjs/FileDownloadResponse.d.ts.map +1 -0
- package/dist/commonjs/FileDownloadResponse.js +371 -0
- package/dist/commonjs/FileDownloadResponse.js.map +1 -0
- package/dist/commonjs/FileSASPermissions.d.ts +42 -0
- package/dist/commonjs/FileSASPermissions.d.ts.map +1 -0
- package/dist/commonjs/FileSASPermissions.js +86 -0
- package/dist/commonjs/FileSASPermissions.js.map +1 -0
- package/dist/commonjs/FileSASSignatureValues.d.ts +95 -0
- package/dist/commonjs/FileSASSignatureValues.d.ts.map +1 -0
- package/dist/commonjs/FileSASSignatureValues.js +88 -0
- package/dist/commonjs/FileSASSignatureValues.js.map +1 -0
- package/dist/commonjs/FileSystemAttributes.d.ts +63 -0
- package/dist/commonjs/FileSystemAttributes.d.ts.map +1 -0
- package/dist/commonjs/FileSystemAttributes.js +148 -0
- package/dist/commonjs/FileSystemAttributes.js.map +1 -0
- package/dist/commonjs/Pipeline.d.ts +142 -0
- package/dist/commonjs/Pipeline.d.ts.map +1 -0
- package/dist/commonjs/Pipeline.js +267 -0
- package/dist/commonjs/Pipeline.js.map +1 -0
- package/dist/commonjs/Range.d.ts +25 -0
- package/dist/commonjs/Range.d.ts.map +1 -0
- package/dist/commonjs/Range.js +25 -0
- package/dist/commonjs/Range.js.map +1 -0
- package/dist/commonjs/SASQueryParameters.d.ts +136 -0
- package/dist/commonjs/SASQueryParameters.d.ts.map +1 -0
- package/dist/commonjs/SASQueryParameters.js +181 -0
- package/dist/commonjs/SASQueryParameters.js.map +1 -0
- package/dist/commonjs/SasIPRange.d.ts +25 -0
- package/dist/commonjs/SasIPRange.d.ts.map +1 -0
- package/dist/commonjs/SasIPRange.js +17 -0
- package/dist/commonjs/SasIPRange.js.map +1 -0
- package/dist/commonjs/ShareClientInternal.d.ts +12 -0
- package/dist/commonjs/ShareClientInternal.d.ts.map +1 -0
- package/dist/commonjs/ShareClientInternal.js +20 -0
- package/dist/commonjs/ShareClientInternal.js.map +1 -0
- package/dist/commonjs/ShareSASPermissions.d.ts +46 -0
- package/dist/commonjs/ShareSASPermissions.d.ts.map +1 -0
- package/dist/commonjs/ShareSASPermissions.js +96 -0
- package/dist/commonjs/ShareSASPermissions.js.map +1 -0
- package/dist/commonjs/ShareServiceClient.d.ts +427 -0
- package/dist/commonjs/ShareServiceClient.d.ts.map +1 -0
- package/dist/commonjs/ShareServiceClient.js +479 -0
- package/dist/commonjs/ShareServiceClient.js.map +1 -0
- package/dist/commonjs/StorageClient.d.ts +47 -0
- package/dist/commonjs/StorageClient.d.ts.map +1 -0
- package/dist/commonjs/StorageClient.js +34 -0
- package/dist/commonjs/StorageClient.js.map +1 -0
- package/dist/commonjs/StorageContextClient.d.ts +9 -0
- package/dist/commonjs/StorageContextClient.d.ts.map +1 -0
- package/dist/commonjs/StorageContextClient.js +22 -0
- package/dist/commonjs/StorageContextClient.js.map +1 -0
- package/dist/commonjs/StorageRetryPolicyFactory.d.ts +56 -0
- package/dist/commonjs/StorageRetryPolicyFactory.d.ts.map +1 -0
- package/dist/commonjs/StorageRetryPolicyFactory.js +31 -0
- package/dist/commonjs/StorageRetryPolicyFactory.js.map +1 -0
- package/dist/commonjs/generated/src/index.d.ts +4 -0
- package/dist/commonjs/generated/src/index.d.ts.map +1 -0
- package/dist/commonjs/generated/src/index.js +16 -0
- package/dist/commonjs/generated/src/index.js.map +1 -0
- package/dist/commonjs/generated/src/models/index.d.ts +2881 -0
- package/dist/commonjs/generated/src/models/index.d.ts.map +1 -0
- package/dist/commonjs/generated/src/models/index.js +169 -0
- package/dist/commonjs/generated/src/models/index.js.map +1 -0
- package/dist/commonjs/generated/src/models/mappers.d.ts +128 -0
- package/dist/commonjs/generated/src/models/mappers.d.ts.map +1 -0
- package/dist/commonjs/generated/src/models/mappers.js +5992 -0
- package/dist/commonjs/generated/src/models/mappers.js.map +1 -0
- package/dist/commonjs/generated/src/models/parameters.d.ts +128 -0
- package/dist/commonjs/generated/src/models/parameters.d.ts.map +1 -0
- package/dist/commonjs/generated/src/models/parameters.js +1369 -0
- package/dist/commonjs/generated/src/models/parameters.js.map +1 -0
- package/dist/commonjs/generated/src/operations/directory.d.ts +65 -0
- package/dist/commonjs/generated/src/operations/directory.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operations/directory.js +383 -0
- package/dist/commonjs/generated/src/operations/directory.js.map +1 -0
- package/dist/commonjs/generated/src/operations/file.d.ts +162 -0
- package/dist/commonjs/generated/src/operations/file.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operations/file.js +871 -0
- package/dist/commonjs/generated/src/operations/file.js.map +1 -0
- package/dist/commonjs/generated/src/operations/index.d.ts +5 -0
- package/dist/commonjs/generated/src/operations/index.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operations/index.js +15 -0
- package/dist/commonjs/generated/src/operations/index.js.map +1 -0
- package/dist/commonjs/generated/src/operations/service.d.ts +32 -0
- package/dist/commonjs/generated/src/operations/service.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operations/service.js +140 -0
- package/dist/commonjs/generated/src/operations/service.js.map +1 -0
- package/dist/commonjs/generated/src/operations/share.d.ts +111 -0
- package/dist/commonjs/generated/src/operations/share.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operations/share.js +676 -0
- package/dist/commonjs/generated/src/operations/share.js.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/directory.d.ts +57 -0
- package/dist/commonjs/generated/src/operationsInterfaces/directory.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/directory.js +10 -0
- package/dist/commonjs/generated/src/operationsInterfaces/directory.js.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/file.d.ts +154 -0
- package/dist/commonjs/generated/src/operationsInterfaces/file.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/file.js +10 -0
- package/dist/commonjs/generated/src/operationsInterfaces/file.js.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/index.d.ts +5 -0
- package/dist/commonjs/generated/src/operationsInterfaces/index.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/index.js +15 -0
- package/dist/commonjs/generated/src/operationsInterfaces/index.js.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/service.d.ts +24 -0
- package/dist/commonjs/generated/src/operationsInterfaces/service.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/service.js +10 -0
- package/dist/commonjs/generated/src/operationsInterfaces/service.js.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/share.d.ts +103 -0
- package/dist/commonjs/generated/src/operationsInterfaces/share.d.ts.map +1 -0
- package/dist/commonjs/generated/src/operationsInterfaces/share.js +10 -0
- package/dist/commonjs/generated/src/operationsInterfaces/share.js.map +1 -0
- package/dist/commonjs/generated/src/storageClient.d.ts +20 -0
- package/dist/commonjs/generated/src/storageClient.d.ts.map +1 -0
- package/dist/commonjs/generated/src/storageClient.js +53 -0
- package/dist/commonjs/generated/src/storageClient.js.map +1 -0
- package/dist/commonjs/generatedModels.d.ts +492 -0
- package/dist/commonjs/generatedModels.d.ts.map +1 -0
- package/dist/commonjs/generatedModels.js +11 -0
- package/dist/commonjs/generatedModels.js.map +1 -0
- package/dist/commonjs/index.d.ts +32 -0
- package/dist/commonjs/index.d.ts.map +1 -0
- package/dist/commonjs/index.js +55 -0
- package/dist/commonjs/index.js.map +1 -0
- package/dist/commonjs/log.d.ts +5 -0
- package/dist/commonjs/log.d.ts.map +1 -0
- package/dist/commonjs/log.js +11 -0
- package/dist/commonjs/log.js.map +1 -0
- package/dist/commonjs/models.d.ts +373 -0
- package/dist/commonjs/models.d.ts.map +1 -0
- package/dist/commonjs/models.js +107 -0
- package/dist/commonjs/models.js.map +1 -0
- package/dist/commonjs/package.json +3 -0
- package/dist/commonjs/policies/StorageRetryPolicy.d.ts +75 -0
- package/dist/commonjs/policies/StorageRetryPolicy.d.ts.map +1 -0
- package/dist/commonjs/policies/StorageRetryPolicy.js +225 -0
- package/dist/commonjs/policies/StorageRetryPolicy.js.map +1 -0
- package/dist/commonjs/policies/StorageRetryPolicyV2.d.ts +24 -0
- package/dist/commonjs/policies/StorageRetryPolicyV2.d.ts.map +1 -0
- package/dist/commonjs/policies/StorageRetryPolicyV2.js +180 -0
- package/dist/commonjs/policies/StorageRetryPolicyV2.js.map +1 -0
- package/dist/commonjs/tsdoc-metadata.json +11 -0
- package/dist/commonjs/utils/Batch.d.ts +68 -0
- package/dist/commonjs/utils/Batch.d.ts.map +1 -0
- package/dist/commonjs/utils/Batch.js +126 -0
- package/dist/commonjs/utils/Batch.js.map +1 -0
- package/dist/commonjs/utils/BufferScheduler.d.ts +157 -0
- package/dist/commonjs/utils/BufferScheduler.d.ts.map +1 -0
- package/dist/commonjs/utils/BufferScheduler.js +268 -0
- package/dist/commonjs/utils/BufferScheduler.js.map +1 -0
- package/dist/commonjs/utils/RetriableReadableStream.d.ts +58 -0
- package/dist/commonjs/utils/RetriableReadableStream.d.ts.map +1 -0
- package/dist/commonjs/utils/RetriableReadableStream.js +123 -0
- package/dist/commonjs/utils/RetriableReadableStream.js.map +1 -0
- package/dist/commonjs/utils/constants.d.ts +55 -0
- package/dist/commonjs/utils/constants.d.ts.map +1 -0
- package/dist/commonjs/utils/constants.js +165 -0
- package/dist/commonjs/utils/constants.js.map +1 -0
- package/dist/commonjs/utils/tracing.d.ts +6 -0
- package/dist/commonjs/utils/tracing.d.ts.map +1 -0
- package/dist/commonjs/utils/tracing.js +17 -0
- package/dist/commonjs/utils/tracing.js.map +1 -0
- package/dist/commonjs/utils/utils.common.d.ts +304 -0
- package/dist/commonjs/utils/utils.common.d.ts.map +1 -0
- package/dist/commonjs/utils/utils.common.js +816 -0
- package/dist/commonjs/utils/utils.common.js.map +1 -0
- package/dist/commonjs/utils/utils.d.ts +28 -0
- package/dist/commonjs/utils/utils.d.ts.map +1 -0
- package/dist/commonjs/utils/utils.js +85 -0
- package/dist/commonjs/utils/utils.js.map +1 -0
- package/dist/esm/AccountSASPermissions.d.ts +61 -0
- package/dist/esm/AccountSASPermissions.d.ts.map +1 -0
- package/dist/esm/AccountSASPermissions.js +128 -0
- package/dist/esm/AccountSASPermissions.js.map +1 -0
- package/dist/esm/AccountSASResourceTypes.d.ts +38 -0
- package/dist/esm/AccountSASResourceTypes.d.ts.map +1 -0
- package/dist/esm/AccountSASResourceTypes.js.map +1 -0
- package/dist/esm/AccountSASServices.d.ts +40 -0
- package/dist/esm/AccountSASServices.d.ts.map +1 -0
- package/dist/esm/AccountSASServices.js.map +1 -0
- package/dist/esm/AccountSASSignatureValues.d.ts +73 -0
- package/dist/esm/AccountSASSignatureValues.d.ts.map +1 -0
- package/dist/esm/AccountSASSignatureValues.js +71 -0
- package/dist/esm/AccountSASSignatureValues.js.map +1 -0
- package/dist/esm/Clients.d.ts +3114 -0
- package/dist/esm/Clients.d.ts.map +1 -0
- package/dist/esm/Clients.js +2882 -0
- package/dist/esm/Clients.js.map +1 -0
- package/dist/esm/FileDownloadResponse.d.ts +291 -0
- package/dist/esm/FileDownloadResponse.d.ts.map +1 -0
- package/dist/esm/FileDownloadResponse.js +367 -0
- package/dist/esm/FileDownloadResponse.js.map +1 -0
- package/dist/esm/FileSASPermissions.d.ts +42 -0
- package/dist/esm/FileSASPermissions.d.ts.map +1 -0
- package/dist/esm/FileSASPermissions.js +82 -0
- package/dist/esm/FileSASPermissions.js.map +1 -0
- package/dist/esm/FileSASSignatureValues.d.ts +95 -0
- package/dist/esm/FileSASSignatureValues.d.ts.map +1 -0
- package/dist/esm/FileSASSignatureValues.js +84 -0
- package/dist/esm/FileSASSignatureValues.js.map +1 -0
- package/dist/esm/FileSystemAttributes.d.ts +63 -0
- package/dist/esm/FileSystemAttributes.d.ts.map +1 -0
- package/dist/esm/FileSystemAttributes.js +144 -0
- package/dist/esm/FileSystemAttributes.js.map +1 -0
- package/dist/esm/Pipeline.d.ts +142 -0
- package/dist/esm/Pipeline.d.ts.map +1 -0
- package/dist/esm/Pipeline.js +261 -0
- package/dist/esm/Pipeline.js.map +1 -0
- package/dist/esm/Range.d.ts +25 -0
- package/dist/esm/Range.d.ts.map +1 -0
- package/dist/esm/Range.js +22 -0
- package/dist/esm/Range.js.map +1 -0
- package/dist/esm/SASQueryParameters.d.ts +136 -0
- package/dist/esm/SASQueryParameters.d.ts.map +1 -0
- package/dist/esm/SASQueryParameters.js +177 -0
- package/dist/esm/SASQueryParameters.js.map +1 -0
- package/dist/esm/SasIPRange.d.ts +25 -0
- package/dist/esm/SasIPRange.d.ts.map +1 -0
- package/dist/esm/SasIPRange.js +14 -0
- package/dist/esm/SasIPRange.js.map +1 -0
- package/dist/esm/ShareClientInternal.d.ts +12 -0
- package/dist/esm/ShareClientInternal.d.ts.map +1 -0
- package/dist/esm/ShareClientInternal.js +16 -0
- package/dist/esm/ShareClientInternal.js.map +1 -0
- package/dist/esm/ShareSASPermissions.d.ts +46 -0
- package/dist/esm/ShareSASPermissions.d.ts.map +1 -0
- package/dist/esm/ShareSASPermissions.js +92 -0
- package/dist/esm/ShareSASPermissions.js.map +1 -0
- package/dist/esm/ShareServiceClient.d.ts +427 -0
- package/dist/esm/ShareServiceClient.d.ts.map +1 -0
- package/dist/esm/ShareServiceClient.js +475 -0
- package/dist/esm/ShareServiceClient.js.map +1 -0
- package/dist/esm/StorageClient.d.ts +47 -0
- package/dist/esm/StorageClient.d.ts.map +1 -0
- package/dist/esm/StorageClient.js +30 -0
- package/dist/esm/StorageClient.js.map +1 -0
- package/dist/esm/StorageContextClient.d.ts +9 -0
- package/dist/esm/StorageContextClient.d.ts.map +1 -0
- package/dist/esm/StorageContextClient.js +18 -0
- package/dist/esm/StorageContextClient.js.map +1 -0
- package/dist/esm/StorageRetryPolicyFactory.d.ts +56 -0
- package/dist/esm/StorageRetryPolicyFactory.d.ts.map +1 -0
- package/dist/esm/StorageRetryPolicyFactory.js +26 -0
- package/dist/esm/StorageRetryPolicyFactory.js.map +1 -0
- package/dist/esm/generated/src/index.d.ts +4 -0
- package/dist/esm/generated/src/index.d.ts.map +1 -0
- package/dist/esm/generated/src/index.js +11 -0
- package/dist/esm/generated/src/index.js.map +1 -0
- package/dist/esm/generated/src/models/index.d.ts +2881 -0
- package/dist/esm/generated/src/models/index.d.ts.map +1 -0
- package/dist/esm/generated/src/models/index.js +166 -0
- package/dist/esm/generated/src/models/index.js.map +1 -0
- package/dist/esm/generated/src/models/mappers.d.ts +128 -0
- package/dist/esm/generated/src/models/mappers.d.ts.map +1 -0
- package/dist/esm/generated/src/models/mappers.js +5987 -0
- package/dist/esm/generated/src/models/mappers.js.map +1 -0
- package/dist/esm/generated/src/models/parameters.d.ts +128 -0
- package/dist/esm/generated/src/models/parameters.d.ts.map +1 -0
- package/dist/esm/generated/src/models/parameters.js +1364 -0
- package/dist/esm/generated/src/models/parameters.js.map +1 -0
- package/dist/esm/generated/src/operations/directory.d.ts +65 -0
- package/dist/esm/generated/src/operations/directory.d.ts.map +1 -0
- package/dist/esm/generated/src/operations/directory.js +378 -0
- package/dist/esm/generated/src/operations/directory.js.map +1 -0
- package/dist/esm/generated/src/operations/file.d.ts +162 -0
- package/dist/esm/generated/src/operations/file.d.ts.map +1 -0
- package/dist/esm/generated/src/operations/file.js +866 -0
- package/dist/esm/generated/src/operations/file.js.map +1 -0
- package/dist/esm/generated/src/operations/index.d.ts +5 -0
- package/dist/esm/generated/src/operations/index.d.ts.map +1 -0
- package/dist/esm/generated/src/operations/index.js +12 -0
- package/dist/esm/generated/src/operations/index.js.map +1 -0
- package/dist/esm/generated/src/operations/service.d.ts +32 -0
- package/dist/esm/generated/src/operations/service.d.ts.map +1 -0
- package/dist/esm/generated/src/operations/service.js +135 -0
- package/dist/esm/generated/src/operations/service.js.map +1 -0
- package/dist/esm/generated/src/operations/share.d.ts +111 -0
- package/dist/esm/generated/src/operations/share.d.ts.map +1 -0
- package/dist/esm/generated/src/operations/share.js +671 -0
- package/dist/esm/generated/src/operations/share.js.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/directory.d.ts +57 -0
- package/dist/esm/generated/src/operationsInterfaces/directory.d.ts.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/directory.js +9 -0
- package/dist/esm/generated/src/operationsInterfaces/directory.js.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/file.d.ts +154 -0
- package/dist/esm/generated/src/operationsInterfaces/file.d.ts.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/file.js +9 -0
- package/dist/esm/generated/src/operationsInterfaces/file.js.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/index.d.ts +5 -0
- package/dist/esm/generated/src/operationsInterfaces/index.d.ts.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/index.js +12 -0
- package/dist/esm/generated/src/operationsInterfaces/index.js.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/service.d.ts +24 -0
- package/dist/esm/generated/src/operationsInterfaces/service.d.ts.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/service.js.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/share.d.ts +103 -0
- package/dist/esm/generated/src/operationsInterfaces/share.d.ts.map +1 -0
- package/dist/esm/generated/src/operationsInterfaces/share.js +9 -0
- package/dist/esm/generated/src/operationsInterfaces/share.js.map +1 -0
- package/dist/esm/generated/src/storageClient.d.ts +20 -0
- package/dist/esm/generated/src/storageClient.d.ts.map +1 -0
- package/dist/esm/generated/src/storageClient.js +48 -0
- package/dist/esm/generated/src/storageClient.js.map +1 -0
- package/dist/esm/generatedModels.d.ts +492 -0
- package/dist/esm/generatedModels.d.ts.map +1 -0
- package/dist/esm/generatedModels.js +8 -0
- package/dist/esm/generatedModels.js.map +1 -0
- package/dist/esm/index.d.ts +32 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +30 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/log.d.ts +5 -0
- package/dist/esm/log.d.ts.map +1 -0
- package/dist/esm/log.js +8 -0
- package/dist/esm/log.js.map +1 -0
- package/dist/esm/models.d.ts +373 -0
- package/dist/esm/models.d.ts.map +1 -0
- package/dist/esm/models.js +94 -0
- package/dist/esm/models.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/policies/StorageRetryPolicy.d.ts +75 -0
- package/dist/esm/policies/StorageRetryPolicy.d.ts.map +1 -0
- package/dist/esm/policies/StorageRetryPolicy.js +220 -0
- package/dist/esm/policies/StorageRetryPolicy.js.map +1 -0
- package/dist/esm/policies/StorageRetryPolicyV2.d.ts +24 -0
- package/dist/esm/policies/StorageRetryPolicyV2.d.ts.map +1 -0
- package/dist/esm/policies/StorageRetryPolicyV2.js +176 -0
- package/dist/esm/policies/StorageRetryPolicyV2.js.map +1 -0
- package/dist/esm/utils/Batch.d.ts +68 -0
- package/dist/esm/utils/Batch.d.ts.map +1 -0
- package/dist/esm/utils/Batch.js.map +1 -0
- package/dist/esm/utils/BufferScheduler.d.ts +157 -0
- package/dist/esm/utils/BufferScheduler.d.ts.map +1 -0
- package/dist/esm/utils/BufferScheduler.js +264 -0
- package/dist/esm/utils/BufferScheduler.js.map +1 -0
- package/dist/esm/utils/RetriableReadableStream.d.ts +58 -0
- package/dist/esm/utils/RetriableReadableStream.d.ts.map +1 -0
- package/dist/esm/utils/RetriableReadableStream.js +119 -0
- package/dist/esm/utils/RetriableReadableStream.js.map +1 -0
- package/dist/esm/utils/constants.d.ts +55 -0
- package/dist/esm/utils/constants.d.ts.map +1 -0
- package/dist/esm/utils/constants.js +162 -0
- package/dist/esm/utils/constants.js.map +1 -0
- package/dist/esm/utils/tracing.d.ts +6 -0
- package/dist/esm/utils/tracing.d.ts.map +1 -0
- package/dist/esm/utils/tracing.js +14 -0
- package/dist/esm/utils/tracing.js.map +1 -0
- package/dist/esm/utils/utils.common.d.ts +304 -0
- package/dist/esm/utils/utils.common.d.ts.map +1 -0
- package/dist/esm/utils/utils.common.js +778 -0
- package/dist/esm/utils/utils.common.js.map +1 -0
- package/dist/esm/utils/utils.d.ts +28 -0
- package/dist/esm/utils/utils.d.ts.map +1 -0
- package/dist/esm/utils/utils.js +79 -0
- package/dist/esm/utils/utils.js.map +1 -0
- package/dist/react-native/AccountSASPermissions.d.ts +61 -0
- package/dist/react-native/AccountSASPermissions.d.ts.map +1 -0
- package/dist/react-native/AccountSASPermissions.js +128 -0
- package/dist/react-native/AccountSASPermissions.js.map +1 -0
- package/dist/react-native/AccountSASResourceTypes.d.ts +38 -0
- package/dist/react-native/AccountSASResourceTypes.d.ts.map +1 -0
- package/dist/react-native/AccountSASResourceTypes.js +72 -0
- package/dist/react-native/AccountSASResourceTypes.js.map +1 -0
- package/dist/react-native/AccountSASServices.d.ts +40 -0
- package/dist/react-native/AccountSASServices.d.ts.map +1 -0
- package/dist/react-native/AccountSASServices.js +80 -0
- package/dist/react-native/AccountSASServices.js.map +1 -0
- package/dist/react-native/AccountSASSignatureValues.d.ts +73 -0
- package/dist/react-native/AccountSASSignatureValues.d.ts.map +1 -0
- package/dist/react-native/AccountSASSignatureValues.js +71 -0
- package/dist/react-native/AccountSASSignatureValues.js.map +1 -0
- package/dist/react-native/Clients.d.ts +3114 -0
- package/dist/react-native/Clients.d.ts.map +1 -0
- package/dist/react-native/Clients.js +2882 -0
- package/dist/react-native/Clients.js.map +1 -0
- package/dist/react-native/FileDownloadResponse.d.ts +291 -0
- package/dist/react-native/FileDownloadResponse.d.ts.map +1 -0
- package/dist/react-native/FileDownloadResponse.js +367 -0
- package/dist/react-native/FileDownloadResponse.js.map +1 -0
- package/dist/react-native/FileSASPermissions.d.ts +42 -0
- package/dist/react-native/FileSASPermissions.d.ts.map +1 -0
- package/dist/react-native/FileSASPermissions.js +82 -0
- package/dist/react-native/FileSASPermissions.js.map +1 -0
- package/dist/react-native/FileSASSignatureValues.d.ts +95 -0
- package/dist/react-native/FileSASSignatureValues.d.ts.map +1 -0
- package/dist/react-native/FileSASSignatureValues.js +84 -0
- package/dist/react-native/FileSASSignatureValues.js.map +1 -0
- package/dist/react-native/FileSystemAttributes.d.ts +63 -0
- package/dist/react-native/FileSystemAttributes.d.ts.map +1 -0
- package/dist/react-native/FileSystemAttributes.js +144 -0
- package/dist/react-native/FileSystemAttributes.js.map +1 -0
- package/dist/react-native/Pipeline.d.ts +142 -0
- package/dist/react-native/Pipeline.d.ts.map +1 -0
- package/dist/react-native/Pipeline.js +261 -0
- package/dist/react-native/Pipeline.js.map +1 -0
- package/dist/react-native/Range.d.ts +25 -0
- package/dist/react-native/Range.d.ts.map +1 -0
- package/dist/react-native/Range.js +22 -0
- package/dist/react-native/Range.js.map +1 -0
- package/dist/react-native/SASQueryParameters.d.ts +136 -0
- package/dist/react-native/SASQueryParameters.d.ts.map +1 -0
- package/dist/react-native/SASQueryParameters.js +177 -0
- package/dist/react-native/SASQueryParameters.js.map +1 -0
- package/dist/react-native/SasIPRange.d.ts +25 -0
- package/dist/react-native/SasIPRange.d.ts.map +1 -0
- package/dist/react-native/SasIPRange.js +14 -0
- package/dist/react-native/SasIPRange.js.map +1 -0
- package/dist/react-native/ShareClientInternal.d.ts +12 -0
- package/dist/react-native/ShareClientInternal.d.ts.map +1 -0
- package/dist/react-native/ShareClientInternal.js +16 -0
- package/dist/react-native/ShareClientInternal.js.map +1 -0
- package/dist/react-native/ShareSASPermissions.d.ts +46 -0
- package/dist/react-native/ShareSASPermissions.d.ts.map +1 -0
- package/dist/react-native/ShareSASPermissions.js +92 -0
- package/dist/react-native/ShareSASPermissions.js.map +1 -0
- package/dist/react-native/ShareServiceClient.d.ts +427 -0
- package/dist/react-native/ShareServiceClient.d.ts.map +1 -0
- package/dist/react-native/ShareServiceClient.js +475 -0
- package/dist/react-native/ShareServiceClient.js.map +1 -0
- package/dist/react-native/StorageClient.d.ts +47 -0
- package/dist/react-native/StorageClient.d.ts.map +1 -0
- package/dist/react-native/StorageClient.js +30 -0
- package/dist/react-native/StorageClient.js.map +1 -0
- package/dist/react-native/StorageContextClient.d.ts +9 -0
- package/dist/react-native/StorageContextClient.d.ts.map +1 -0
- package/dist/react-native/StorageContextClient.js +18 -0
- package/dist/react-native/StorageContextClient.js.map +1 -0
- package/dist/react-native/StorageRetryPolicyFactory.d.ts +56 -0
- package/dist/react-native/StorageRetryPolicyFactory.d.ts.map +1 -0
- package/dist/react-native/StorageRetryPolicyFactory.js +26 -0
- package/dist/react-native/StorageRetryPolicyFactory.js.map +1 -0
- package/dist/react-native/generated/src/index.d.ts +4 -0
- package/dist/react-native/generated/src/index.d.ts.map +1 -0
- package/dist/react-native/generated/src/index.js +11 -0
- package/dist/react-native/generated/src/index.js.map +1 -0
- package/dist/react-native/generated/src/models/index.d.ts +2881 -0
- package/dist/react-native/generated/src/models/index.d.ts.map +1 -0
- package/dist/react-native/generated/src/models/index.js +166 -0
- package/dist/react-native/generated/src/models/index.js.map +1 -0
- package/dist/react-native/generated/src/models/mappers.d.ts +128 -0
- package/dist/react-native/generated/src/models/mappers.d.ts.map +1 -0
- package/dist/react-native/generated/src/models/mappers.js +5987 -0
- package/dist/react-native/generated/src/models/mappers.js.map +1 -0
- package/dist/react-native/generated/src/models/parameters.d.ts +128 -0
- package/dist/react-native/generated/src/models/parameters.d.ts.map +1 -0
- package/dist/react-native/generated/src/models/parameters.js +1364 -0
- package/dist/react-native/generated/src/models/parameters.js.map +1 -0
- package/dist/react-native/generated/src/operations/directory.d.ts +65 -0
- package/dist/react-native/generated/src/operations/directory.d.ts.map +1 -0
- package/dist/react-native/generated/src/operations/directory.js +378 -0
- package/dist/react-native/generated/src/operations/directory.js.map +1 -0
- package/dist/react-native/generated/src/operations/file.d.ts +162 -0
- package/dist/react-native/generated/src/operations/file.d.ts.map +1 -0
- package/dist/react-native/generated/src/operations/file.js +866 -0
- package/dist/react-native/generated/src/operations/file.js.map +1 -0
- package/dist/react-native/generated/src/operations/index.d.ts +5 -0
- package/dist/react-native/generated/src/operations/index.d.ts.map +1 -0
- package/dist/react-native/generated/src/operations/index.js +12 -0
- package/dist/react-native/generated/src/operations/index.js.map +1 -0
- package/dist/react-native/generated/src/operations/service.d.ts +32 -0
- package/dist/react-native/generated/src/operations/service.d.ts.map +1 -0
- package/dist/react-native/generated/src/operations/service.js +135 -0
- package/dist/react-native/generated/src/operations/service.js.map +1 -0
- package/dist/react-native/generated/src/operations/share.d.ts +111 -0
- package/dist/react-native/generated/src/operations/share.d.ts.map +1 -0
- package/dist/react-native/generated/src/operations/share.js +671 -0
- package/dist/react-native/generated/src/operations/share.js.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/directory.d.ts +57 -0
- package/dist/react-native/generated/src/operationsInterfaces/directory.d.ts.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/directory.js +9 -0
- package/dist/react-native/generated/src/operationsInterfaces/directory.js.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/file.d.ts +154 -0
- package/dist/react-native/generated/src/operationsInterfaces/file.d.ts.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/file.js +9 -0
- package/dist/react-native/generated/src/operationsInterfaces/file.js.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/index.d.ts +5 -0
- package/dist/react-native/generated/src/operationsInterfaces/index.d.ts.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/index.js +12 -0
- package/dist/react-native/generated/src/operationsInterfaces/index.js.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/service.d.ts +24 -0
- package/dist/react-native/generated/src/operationsInterfaces/service.d.ts.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/service.js +9 -0
- package/dist/react-native/generated/src/operationsInterfaces/service.js.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/share.d.ts +103 -0
- package/dist/react-native/generated/src/operationsInterfaces/share.d.ts.map +1 -0
- package/dist/react-native/generated/src/operationsInterfaces/share.js +9 -0
- package/dist/react-native/generated/src/operationsInterfaces/share.js.map +1 -0
- package/dist/react-native/generated/src/storageClient.d.ts +20 -0
- package/dist/react-native/generated/src/storageClient.d.ts.map +1 -0
- package/dist/react-native/generated/src/storageClient.js +48 -0
- package/dist/react-native/generated/src/storageClient.js.map +1 -0
- package/dist/react-native/generatedModels.d.ts +492 -0
- package/dist/react-native/generatedModels.d.ts.map +1 -0
- package/dist/react-native/generatedModels.js +8 -0
- package/dist/react-native/generatedModels.js.map +1 -0
- package/dist/react-native/index.d.ts +32 -0
- package/dist/react-native/index.d.ts.map +1 -0
- package/dist/react-native/index.js +30 -0
- package/dist/react-native/index.js.map +1 -0
- package/dist/react-native/log.d.ts +5 -0
- package/dist/react-native/log.d.ts.map +1 -0
- package/dist/react-native/log.js +8 -0
- package/dist/react-native/log.js.map +1 -0
- package/dist/react-native/models.d.ts +373 -0
- package/dist/react-native/models.d.ts.map +1 -0
- package/dist/react-native/models.js +94 -0
- package/dist/react-native/models.js.map +1 -0
- package/dist/react-native/package.json +3 -0
- package/dist/react-native/policies/StorageRetryPolicy.d.ts +75 -0
- package/dist/react-native/policies/StorageRetryPolicy.d.ts.map +1 -0
- package/dist/react-native/policies/StorageRetryPolicy.js +220 -0
- package/dist/react-native/policies/StorageRetryPolicy.js.map +1 -0
- package/dist/react-native/policies/StorageRetryPolicyV2.d.ts +24 -0
- package/dist/react-native/policies/StorageRetryPolicyV2.d.ts.map +1 -0
- package/dist/react-native/policies/StorageRetryPolicyV2.js +176 -0
- package/dist/react-native/policies/StorageRetryPolicyV2.js.map +1 -0
- package/dist/react-native/utils/Batch.d.ts +68 -0
- package/dist/react-native/utils/Batch.d.ts.map +1 -0
- package/dist/react-native/utils/Batch.js +122 -0
- package/dist/react-native/utils/Batch.js.map +1 -0
- package/dist/react-native/utils/BufferScheduler.d.ts +157 -0
- package/dist/react-native/utils/BufferScheduler.d.ts.map +1 -0
- package/dist/react-native/utils/BufferScheduler.js +264 -0
- package/dist/react-native/utils/BufferScheduler.js.map +1 -0
- package/dist/react-native/utils/RetriableReadableStream.d.ts +58 -0
- package/dist/react-native/utils/RetriableReadableStream.d.ts.map +1 -0
- package/dist/react-native/utils/RetriableReadableStream.js +119 -0
- package/dist/react-native/utils/RetriableReadableStream.js.map +1 -0
- package/dist/react-native/utils/constants.d.ts +55 -0
- package/dist/react-native/utils/constants.d.ts.map +1 -0
- package/dist/react-native/utils/constants.js +162 -0
- package/dist/react-native/utils/constants.js.map +1 -0
- package/dist/react-native/utils/tracing.d.ts +6 -0
- package/dist/react-native/utils/tracing.d.ts.map +1 -0
- package/dist/react-native/utils/tracing.js +14 -0
- package/dist/react-native/utils/tracing.js.map +1 -0
- package/dist/react-native/utils/utils.common.d.ts +304 -0
- package/dist/react-native/utils/utils.common.d.ts.map +1 -0
- package/dist/react-native/utils/utils.common.js +778 -0
- package/dist/react-native/utils/utils.common.js.map +1 -0
- package/dist/react-native/utils/utils.d.ts +28 -0
- package/dist/react-native/utils/utils.d.ts.map +1 -0
- package/dist/react-native/utils/utils.js +79 -0
- package/dist/react-native/utils/utils.js.map +1 -0
- package/package.json +69 -74
- package/dist/index.js +0 -16901
- package/dist/index.js.map +0 -1
- package/dist-esm/storage-blob/src/BatchResponse.js +0 -4
- package/dist-esm/storage-blob/src/BatchResponse.js.map +0 -1
- package/dist-esm/storage-blob/src/BatchResponseParser.js +0 -137
- package/dist-esm/storage-blob/src/BatchResponseParser.js.map +0 -1
- package/dist-esm/storage-blob/src/BatchUtils.js +0 -15
- package/dist-esm/storage-blob/src/BatchUtils.js.map +0 -1
- package/dist-esm/storage-blob/src/BlobBatch.js +0 -267
- package/dist-esm/storage-blob/src/BlobBatch.js.map +0 -1
- package/dist-esm/storage-blob/src/BlobBatchClient.js +0 -140
- package/dist-esm/storage-blob/src/BlobBatchClient.js.map +0 -1
- package/dist-esm/storage-blob/src/BlobDownloadResponse.js +0 -463
- package/dist-esm/storage-blob/src/BlobDownloadResponse.js.map +0 -1
- package/dist-esm/storage-blob/src/BlobLeaseClient.js +0 -192
- package/dist-esm/storage-blob/src/BlobLeaseClient.js.map +0 -1
- package/dist-esm/storage-blob/src/BlobQueryResponse.js +0 -367
- package/dist-esm/storage-blob/src/BlobQueryResponse.js.map +0 -1
- package/dist-esm/storage-blob/src/BlobServiceClient.js +0 -716
- package/dist-esm/storage-blob/src/BlobServiceClient.js.map +0 -1
- package/dist-esm/storage-blob/src/Clients.js +0 -2594
- package/dist-esm/storage-blob/src/Clients.js.map +0 -1
- package/dist-esm/storage-blob/src/ContainerClient.js +0 -1209
- package/dist-esm/storage-blob/src/ContainerClient.js.map +0 -1
- package/dist-esm/storage-blob/src/PageBlobRangeResponse.js +0 -24
- package/dist-esm/storage-blob/src/PageBlobRangeResponse.js.map +0 -1
- package/dist-esm/storage-blob/src/Pipeline.js +0 -261
- package/dist-esm/storage-blob/src/Pipeline.js.map +0 -1
- package/dist-esm/storage-blob/src/Range.js +0 -21
- package/dist-esm/storage-blob/src/Range.js.map +0 -1
- package/dist-esm/storage-blob/src/StorageBrowserPolicyFactory.js +0 -19
- package/dist-esm/storage-blob/src/StorageBrowserPolicyFactory.js.map +0 -1
- package/dist-esm/storage-blob/src/StorageClient.js +0 -29
- package/dist-esm/storage-blob/src/StorageClient.js.map +0 -1
- package/dist-esm/storage-blob/src/StorageContextClient.js +0 -17
- package/dist-esm/storage-blob/src/StorageContextClient.js.map +0 -1
- package/dist-esm/storage-blob/src/StorageRetryPolicyFactory.js +0 -26
- package/dist-esm/storage-blob/src/StorageRetryPolicyFactory.js.map +0 -1
- package/dist-esm/storage-blob/src/credentials/AnonymousCredential.js +0 -22
- package/dist-esm/storage-blob/src/credentials/AnonymousCredential.js.map +0 -1
- package/dist-esm/storage-blob/src/credentials/Credential.js +0 -18
- package/dist-esm/storage-blob/src/credentials/Credential.js.map +0 -1
- package/dist-esm/storage-blob/src/credentials/StorageSharedKeyCredential.browser.js +0 -5
- package/dist-esm/storage-blob/src/credentials/StorageSharedKeyCredential.browser.js.map +0 -1
- package/dist-esm/storage-blob/src/credentials/StorageSharedKeyCredential.js +0 -40
- package/dist-esm/storage-blob/src/credentials/StorageSharedKeyCredential.js.map +0 -1
- package/dist-esm/storage-blob/src/credentials/UserDelegationKeyCredential.browser.js +0 -5
- package/dist-esm/storage-blob/src/credentials/UserDelegationKeyCredential.browser.js.map +0 -1
- package/dist-esm/storage-blob/src/credentials/UserDelegationKeyCredential.js +0 -31
- package/dist-esm/storage-blob/src/credentials/UserDelegationKeyCredential.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/index.js +0 -11
- package/dist-esm/storage-blob/src/generated/src/index.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/models/index.js +0 -258
- package/dist-esm/storage-blob/src/generated/src/models/index.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/models/mappers.js +0 -8225
- package/dist-esm/storage-blob/src/generated/src/models/mappers.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/models/parameters.js +0 -1610
- package/dist-esm/storage-blob/src/generated/src/models/parameters.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operations/appendBlob.js +0 -221
- package/dist-esm/storage-blob/src/generated/src/operations/appendBlob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operations/blob.js +0 -1020
- package/dist-esm/storage-blob/src/generated/src/operations/blob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operations/blockBlob.js +0 -365
- package/dist-esm/storage-blob/src/generated/src/operations/blockBlob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operations/container.js +0 -713
- package/dist-esm/storage-blob/src/generated/src/operations/container.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operations/index.js +0 -14
- package/dist-esm/storage-blob/src/generated/src/operations/index.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operations/pageBlob.js +0 -456
- package/dist-esm/storage-blob/src/generated/src/operations/pageBlob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operations/service.js +0 -323
- package/dist-esm/storage-blob/src/generated/src/operations/service.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/appendBlob.js +0 -9
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/appendBlob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/blob.js +0 -9
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/blob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/blockBlob.js +0 -9
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/blockBlob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/container.js +0 -9
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/container.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/index.js +0 -14
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/index.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/pageBlob.js +0 -9
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/pageBlob.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/operationsInterfaces/service.js.map +0 -1
- package/dist-esm/storage-blob/src/generated/src/storageClient.js +0 -49
- package/dist-esm/storage-blob/src/generated/src/storageClient.js.map +0 -1
- package/dist-esm/storage-blob/src/generatedModels.js +0 -8
- package/dist-esm/storage-blob/src/generatedModels.js.map +0 -1
- package/dist-esm/storage-blob/src/index.js +0 -33
- package/dist-esm/storage-blob/src/index.js.map +0 -1
- package/dist-esm/storage-blob/src/log.js +0 -8
- package/dist-esm/storage-blob/src/log.js.map +0 -1
- package/dist-esm/storage-blob/src/models.js +0 -115
- package/dist-esm/storage-blob/src/models.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/AnonymousCredentialPolicy.js +0 -20
- package/dist-esm/storage-blob/src/policies/AnonymousCredentialPolicy.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/CredentialPolicy.js +0 -29
- package/dist-esm/storage-blob/src/policies/CredentialPolicy.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/RequestPolicy.js +0 -40
- package/dist-esm/storage-blob/src/policies/RequestPolicy.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageBrowserPolicy.js +0 -47
- package/dist-esm/storage-blob/src/policies/StorageBrowserPolicy.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageBrowserPolicyV2.js +0 -31
- package/dist-esm/storage-blob/src/policies/StorageBrowserPolicyV2.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageCorrectContentLengthPolicy.browser.js +0 -18
- package/dist-esm/storage-blob/src/policies/StorageCorrectContentLengthPolicy.browser.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageCorrectContentLengthPolicy.js +0 -27
- package/dist-esm/storage-blob/src/policies/StorageCorrectContentLengthPolicy.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageRetryPolicy.js +0 -229
- package/dist-esm/storage-blob/src/policies/StorageRetryPolicy.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageRetryPolicyV2.js +0 -180
- package/dist-esm/storage-blob/src/policies/StorageRetryPolicyV2.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageSharedKeyCredentialPolicy.js +0 -141
- package/dist-esm/storage-blob/src/policies/StorageSharedKeyCredentialPolicy.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageSharedKeyCredentialPolicyV2.browser.js +0 -18
- package/dist-esm/storage-blob/src/policies/StorageSharedKeyCredentialPolicyV2.browser.js.map +0 -1
- package/dist-esm/storage-blob/src/policies/StorageSharedKeyCredentialPolicyV2.js +0 -132
- package/dist-esm/storage-blob/src/policies/StorageSharedKeyCredentialPolicyV2.js.map +0 -1
- package/dist-esm/storage-blob/src/pollers/BlobStartCopyFromUrlPoller.js +0 -130
- package/dist-esm/storage-blob/src/pollers/BlobStartCopyFromUrlPoller.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/AccountSASPermissions.js +0 -227
- package/dist-esm/storage-blob/src/sas/AccountSASPermissions.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/AccountSASResourceTypes.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/AccountSASServices.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/AccountSASSignatureValues.js +0 -100
- package/dist-esm/storage-blob/src/sas/AccountSASSignatureValues.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/BlobSASPermissions.js +0 -195
- package/dist-esm/storage-blob/src/sas/BlobSASPermissions.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/BlobSASSignatureValues.js +0 -576
- package/dist-esm/storage-blob/src/sas/BlobSASSignatureValues.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/ContainerSASPermissions.js +0 -221
- package/dist-esm/storage-blob/src/sas/ContainerSASPermissions.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/SASQueryParameters.js +0 -234
- package/dist-esm/storage-blob/src/sas/SASQueryParameters.js.map +0 -1
- package/dist-esm/storage-blob/src/sas/SasIPRange.js +0 -13
- package/dist-esm/storage-blob/src/sas/SasIPRange.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/Batch.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/BlobQuickQueryStream.js +0 -111
- package/dist-esm/storage-blob/src/utils/BlobQuickQueryStream.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/Mutex.js +0 -65
- package/dist-esm/storage-blob/src/utils/Mutex.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/RetriableReadableStream.js +0 -119
- package/dist-esm/storage-blob/src/utils/RetriableReadableStream.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/SharedKeyComparator.js +0 -73
- package/dist-esm/storage-blob/src/utils/SharedKeyComparator.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/cache.js +0 -11
- package/dist-esm/storage-blob/src/utils/cache.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/constants.js +0 -226
- package/dist-esm/storage-blob/src/utils/constants.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/tracing.js +0 -14
- package/dist-esm/storage-blob/src/utils/tracing.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/utils.common.js +0 -756
- package/dist-esm/storage-blob/src/utils/utils.common.js.map +0 -1
- package/dist-esm/storage-blob/src/utils/utils.node.js +0 -132
- package/dist-esm/storage-blob/src/utils/utils.node.js.map +0 -1
- package/dist-esm/storage-file-share/src/AccountSASPermissions.js.map +0 -1
- package/dist-esm/storage-file-share/src/AccountSASResourceTypes.js.map +0 -1
- package/dist-esm/storage-file-share/src/AccountSASServices.js.map +0 -1
- package/dist-esm/storage-file-share/src/AccountSASSignatureValues.js +0 -71
- package/dist-esm/storage-file-share/src/AccountSASSignatureValues.js.map +0 -1
- package/dist-esm/storage-file-share/src/Clients.js +0 -2642
- package/dist-esm/storage-file-share/src/Clients.js.map +0 -1
- package/dist-esm/storage-file-share/src/FileDownloadResponse.browser.js +0 -7
- package/dist-esm/storage-file-share/src/FileDownloadResponse.browser.js.map +0 -1
- package/dist-esm/storage-file-share/src/FileDownloadResponse.js +0 -367
- package/dist-esm/storage-file-share/src/FileDownloadResponse.js.map +0 -1
- package/dist-esm/storage-file-share/src/FileSASPermissions.js.map +0 -1
- package/dist-esm/storage-file-share/src/FileSASSignatureValues.js +0 -84
- package/dist-esm/storage-file-share/src/FileSASSignatureValues.js.map +0 -1
- package/dist-esm/storage-file-share/src/FileSystemAttributes.js.map +0 -1
- package/dist-esm/storage-file-share/src/Pipeline.js +0 -261
- package/dist-esm/storage-file-share/src/Pipeline.js.map +0 -1
- package/dist-esm/storage-file-share/src/Range.js.map +0 -1
- package/dist-esm/storage-file-share/src/SASQueryParameters.js +0 -177
- package/dist-esm/storage-file-share/src/SASQueryParameters.js.map +0 -1
- package/dist-esm/storage-file-share/src/SasIPRange.js.map +0 -1
- package/dist-esm/storage-file-share/src/ShareClientInternal.js +0 -16
- package/dist-esm/storage-file-share/src/ShareClientInternal.js.map +0 -1
- package/dist-esm/storage-file-share/src/ShareSASPermissions.js.map +0 -1
- package/dist-esm/storage-file-share/src/ShareServiceClient.js +0 -429
- package/dist-esm/storage-file-share/src/ShareServiceClient.js.map +0 -1
- package/dist-esm/storage-file-share/src/StorageClient.js +0 -30
- package/dist-esm/storage-file-share/src/StorageClient.js.map +0 -1
- package/dist-esm/storage-file-share/src/StorageContextClient.js +0 -18
- package/dist-esm/storage-file-share/src/StorageContextClient.js.map +0 -1
- package/dist-esm/storage-file-share/src/StorageRetryPolicyFactory.js +0 -26
- package/dist-esm/storage-file-share/src/StorageRetryPolicyFactory.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/index.js +0 -11
- package/dist-esm/storage-file-share/src/generated/src/index.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/models/index.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/models/mappers.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/models/parameters.js +0 -1364
- package/dist-esm/storage-file-share/src/generated/src/models/parameters.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operations/directory.js +0 -378
- package/dist-esm/storage-file-share/src/generated/src/operations/directory.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operations/file.js +0 -866
- package/dist-esm/storage-file-share/src/generated/src/operations/file.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operations/index.js +0 -12
- package/dist-esm/storage-file-share/src/generated/src/operations/index.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operations/service.js +0 -135
- package/dist-esm/storage-file-share/src/generated/src/operations/service.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operations/share.js +0 -671
- package/dist-esm/storage-file-share/src/generated/src/operations/share.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operationsInterfaces/directory.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operationsInterfaces/file.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operationsInterfaces/index.js +0 -12
- package/dist-esm/storage-file-share/src/generated/src/operationsInterfaces/index.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operationsInterfaces/service.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/operationsInterfaces/share.js.map +0 -1
- package/dist-esm/storage-file-share/src/generated/src/storageClient.js +0 -48
- package/dist-esm/storage-file-share/src/generated/src/storageClient.js.map +0 -1
- package/dist-esm/storage-file-share/src/generatedModels.js.map +0 -1
- package/dist-esm/storage-file-share/src/index.browser.js +0 -19
- package/dist-esm/storage-file-share/src/index.browser.js.map +0 -1
- package/dist-esm/storage-file-share/src/index.js +0 -30
- package/dist-esm/storage-file-share/src/index.js.map +0 -1
- package/dist-esm/storage-file-share/src/log.js.map +0 -1
- package/dist-esm/storage-file-share/src/models.js +0 -94
- package/dist-esm/storage-file-share/src/models.js.map +0 -1
- package/dist-esm/storage-file-share/src/policies/StorageRetryPolicy.js +0 -220
- package/dist-esm/storage-file-share/src/policies/StorageRetryPolicy.js.map +0 -1
- package/dist-esm/storage-file-share/src/policies/StorageRetryPolicyV2.js +0 -176
- package/dist-esm/storage-file-share/src/policies/StorageRetryPolicyV2.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/Batch.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/BufferScheduler.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/RetriableReadableStream.js +0 -119
- package/dist-esm/storage-file-share/src/utils/RetriableReadableStream.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/constants.js +0 -162
- package/dist-esm/storage-file-share/src/utils/constants.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/tracing.js +0 -14
- package/dist-esm/storage-file-share/src/utils/tracing.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/utils.browser.js +0 -30
- package/dist-esm/storage-file-share/src/utils/utils.browser.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/utils.common.js +0 -777
- package/dist-esm/storage-file-share/src/utils/utils.common.js.map +0 -1
- package/dist-esm/storage-file-share/src/utils/utils.node.js +0 -79
- package/dist-esm/storage-file-share/src/utils/utils.node.js.map +0 -1
- package/types/latest/storage-file-share.d.ts +0 -8411
- /package/{dist-esm/storage-file-share/src → dist/browser}/AccountSASPermissions.js +0 -0
- /package/{dist-esm/storage-blob/src/sas → dist/browser}/AccountSASResourceTypes.js +0 -0
- /package/{dist-esm/storage-blob/src/sas → dist/browser}/AccountSASServices.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/FileSASPermissions.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/FileSystemAttributes.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/Range.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/SasIPRange.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/ShareSASPermissions.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/generated/src/models/index.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/generated/src/models/mappers.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/generated/src/operationsInterfaces/directory.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/generated/src/operationsInterfaces/file.js +0 -0
- /package/{dist-esm/storage-blob/src → dist/browser}/generated/src/operationsInterfaces/service.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/generated/src/operationsInterfaces/share.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/generatedModels.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/log.js +0 -0
- /package/{dist-esm/storage-blob/src → dist/browser}/utils/Batch.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/browser}/utils/BufferScheduler.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/esm}/AccountSASResourceTypes.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/esm}/AccountSASServices.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/esm}/generated/src/operationsInterfaces/service.js +0 -0
- /package/{dist-esm/storage-file-share/src → dist/esm}/utils/Batch.js +0 -0
@@ -1,220 +0,0 @@
|
|
1
|
-
// Copyright (c) Microsoft Corporation.
|
2
|
-
// Licensed under the MIT License.
|
3
|
-
import { AbortError } from "@azure/abort-controller";
|
4
|
-
import { BaseRequestPolicy } from "../../../storage-blob/src/policies/RequestPolicy";
|
5
|
-
import { URLConstants } from "../utils/constants";
|
6
|
-
import { delay, setURLParameter } from "../utils/utils.common";
|
7
|
-
import { logger } from "../log";
|
8
|
-
/**
|
9
|
-
* A factory method used to generated a RetryPolicy factory.
|
10
|
-
*
|
11
|
-
* @param retryOptions -
|
12
|
-
*/
|
13
|
-
export function NewRetryPolicyFactory(retryOptions) {
|
14
|
-
return {
|
15
|
-
create: (nextPolicy, options) => {
|
16
|
-
return new StorageRetryPolicy(nextPolicy, options, retryOptions);
|
17
|
-
},
|
18
|
-
};
|
19
|
-
}
|
20
|
-
/**
|
21
|
-
* RetryPolicy types.
|
22
|
-
*/
|
23
|
-
export var StorageRetryPolicyType;
|
24
|
-
(function (StorageRetryPolicyType) {
|
25
|
-
/**
|
26
|
-
* Exponential retry. Retry time delay grows exponentially.
|
27
|
-
*/
|
28
|
-
StorageRetryPolicyType[StorageRetryPolicyType["EXPONENTIAL"] = 0] = "EXPONENTIAL";
|
29
|
-
/**
|
30
|
-
* Linear retry. Retry time delay grows linearly.
|
31
|
-
*/
|
32
|
-
StorageRetryPolicyType[StorageRetryPolicyType["FIXED"] = 1] = "FIXED";
|
33
|
-
})(StorageRetryPolicyType || (StorageRetryPolicyType = {}));
|
34
|
-
// Default values of StorageRetryOptions
|
35
|
-
const DEFAULT_RETRY_OPTIONS = {
|
36
|
-
maxRetryDelayInMs: 120 * 1000,
|
37
|
-
maxTries: 4,
|
38
|
-
retryDelayInMs: 4 * 1000,
|
39
|
-
retryPolicyType: StorageRetryPolicyType.EXPONENTIAL,
|
40
|
-
tryTimeoutInMs: undefined, // Use server side default timeout strategy
|
41
|
-
};
|
42
|
-
const RETRY_ABORT_ERROR = new AbortError("The operation was aborted.");
|
43
|
-
/**
|
44
|
-
* Retry policy with exponential retry and linear retry implemented.
|
45
|
-
*/
|
46
|
-
export class StorageRetryPolicy extends BaseRequestPolicy {
|
47
|
-
/**
|
48
|
-
* Creates an instance of RetryPolicy.
|
49
|
-
*
|
50
|
-
* @param nextPolicy -
|
51
|
-
* @param options -
|
52
|
-
* @param retryOptions -
|
53
|
-
*/
|
54
|
-
constructor(nextPolicy, options, retryOptions = DEFAULT_RETRY_OPTIONS) {
|
55
|
-
super(nextPolicy, options);
|
56
|
-
// Initialize retry options
|
57
|
-
this.retryOptions = {
|
58
|
-
retryPolicyType: retryOptions.retryPolicyType
|
59
|
-
? retryOptions.retryPolicyType
|
60
|
-
: DEFAULT_RETRY_OPTIONS.retryPolicyType,
|
61
|
-
maxTries: retryOptions.maxTries && retryOptions.maxTries >= 1
|
62
|
-
? Math.floor(retryOptions.maxTries)
|
63
|
-
: DEFAULT_RETRY_OPTIONS.maxTries,
|
64
|
-
tryTimeoutInMs: retryOptions.tryTimeoutInMs && retryOptions.tryTimeoutInMs >= 0
|
65
|
-
? retryOptions.tryTimeoutInMs
|
66
|
-
: DEFAULT_RETRY_OPTIONS.tryTimeoutInMs,
|
67
|
-
retryDelayInMs: retryOptions.retryDelayInMs && retryOptions.retryDelayInMs >= 0
|
68
|
-
? Math.min(retryOptions.retryDelayInMs, retryOptions.maxRetryDelayInMs
|
69
|
-
? retryOptions.maxRetryDelayInMs
|
70
|
-
: DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs)
|
71
|
-
: DEFAULT_RETRY_OPTIONS.retryDelayInMs,
|
72
|
-
maxRetryDelayInMs: retryOptions.maxRetryDelayInMs && retryOptions.maxRetryDelayInMs >= 0
|
73
|
-
? retryOptions.maxRetryDelayInMs
|
74
|
-
: DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs,
|
75
|
-
};
|
76
|
-
}
|
77
|
-
/**
|
78
|
-
* Sends request.
|
79
|
-
*
|
80
|
-
* @param request -
|
81
|
-
*/
|
82
|
-
async sendRequest(request) {
|
83
|
-
return this.attemptSendRequest(request, false, 1);
|
84
|
-
}
|
85
|
-
/**
|
86
|
-
* Decide and perform next retry. Won't mutate request parameter.
|
87
|
-
*
|
88
|
-
* @param request -
|
89
|
-
* @param secondaryHas404 - If attempt was against the secondary & it returned a StatusNotFound (404), then
|
90
|
-
* the resource was not found. This may be due to replication delay. So, in this
|
91
|
-
* case, we'll never try the secondary again for this operation.
|
92
|
-
* @param attempt - How many retries has been attempted to performed, starting from 1, which includes
|
93
|
-
* the attempt will be performed by this method call.
|
94
|
-
*/
|
95
|
-
async attemptSendRequest(request, secondaryHas404, attempt) {
|
96
|
-
const newRequest = request.clone();
|
97
|
-
const isPrimaryRetry = true;
|
98
|
-
// Set the server-side timeout query parameter "timeout=[seconds]"
|
99
|
-
if (this.retryOptions.tryTimeoutInMs) {
|
100
|
-
newRequest.url = setURLParameter(newRequest.url, URLConstants.Parameters.TIMEOUT, Math.floor(this.retryOptions.tryTimeoutInMs / 1000).toString());
|
101
|
-
}
|
102
|
-
let response;
|
103
|
-
try {
|
104
|
-
logger.info(`RetryPolicy: =====> Try=${attempt} ${isPrimaryRetry ? "Primary" : "Secondary"}`);
|
105
|
-
response = await this._nextPolicy.sendRequest(newRequest);
|
106
|
-
if (!this.shouldRetry(isPrimaryRetry, attempt, response)) {
|
107
|
-
return response;
|
108
|
-
}
|
109
|
-
secondaryHas404 = secondaryHas404 || (!isPrimaryRetry && response.status === 404);
|
110
|
-
}
|
111
|
-
catch (err) {
|
112
|
-
logger.error(`RetryPolicy: Caught error, message: ${err.message}, code: ${err.code}`);
|
113
|
-
if (!this.shouldRetry(isPrimaryRetry, attempt, response, err)) {
|
114
|
-
throw err;
|
115
|
-
}
|
116
|
-
}
|
117
|
-
await this.delay(isPrimaryRetry, attempt, request.abortSignal);
|
118
|
-
return this.attemptSendRequest(request, secondaryHas404, ++attempt);
|
119
|
-
}
|
120
|
-
/**
|
121
|
-
* Decide whether to retry according to last HTTP response and retry counters.
|
122
|
-
*
|
123
|
-
* @param isPrimaryRetry -
|
124
|
-
* @param attempt -
|
125
|
-
* @param response -
|
126
|
-
* @param err -
|
127
|
-
*/
|
128
|
-
shouldRetry(isPrimaryRetry, attempt, response, err) {
|
129
|
-
if (attempt >= this.retryOptions.maxTries) {
|
130
|
-
logger.info(`RetryPolicy: Attempt(s) ${attempt} >= maxTries ${this.retryOptions
|
131
|
-
.maxTries}, no further try.`);
|
132
|
-
return false;
|
133
|
-
}
|
134
|
-
// Handle network failures, you may need to customize the list when you implement
|
135
|
-
// your own http client
|
136
|
-
const retriableErrors = [
|
137
|
-
"ETIMEDOUT",
|
138
|
-
"ESOCKETTIMEDOUT",
|
139
|
-
"ECONNREFUSED",
|
140
|
-
"ECONNRESET",
|
141
|
-
"ENOENT",
|
142
|
-
"ENOTFOUND",
|
143
|
-
"TIMEOUT",
|
144
|
-
"EPIPE",
|
145
|
-
"REQUEST_SEND_ERROR", // For default xhr based http client provided in ms-rest-js
|
146
|
-
];
|
147
|
-
if (err) {
|
148
|
-
for (const retriableError of retriableErrors) {
|
149
|
-
if (err.name.toUpperCase().includes(retriableError) ||
|
150
|
-
err.message.toUpperCase().includes(retriableError) ||
|
151
|
-
(err.code && err.code.toString().toUpperCase() === retriableError)) {
|
152
|
-
logger.info(`RetryPolicy: Network error ${retriableError} found, will retry.`);
|
153
|
-
return true;
|
154
|
-
}
|
155
|
-
}
|
156
|
-
}
|
157
|
-
// If attempt was against the secondary & it returned a StatusNotFound (404), then
|
158
|
-
// the resource was not found. This may be due to replication delay. So, in this
|
159
|
-
// case, we'll never try the secondary again for this operation.
|
160
|
-
if (response || err) {
|
161
|
-
const statusCode = response ? response.status : err ? err.statusCode : 0;
|
162
|
-
if (!isPrimaryRetry && statusCode === 404) {
|
163
|
-
logger.info(`RetryPolicy: Secondary access with 404, will retry.`);
|
164
|
-
return true;
|
165
|
-
}
|
166
|
-
// Server internal error or server timeout
|
167
|
-
if (statusCode === 503 || statusCode === 500) {
|
168
|
-
logger.info(`RetryPolicy: Will retry for status code ${statusCode}.`);
|
169
|
-
return true;
|
170
|
-
}
|
171
|
-
}
|
172
|
-
// [Copy source error code] Feature is pending on service side, skip retry on copy source error for now.
|
173
|
-
// if (response) {
|
174
|
-
// // Retry select Copy Source Error Codes.
|
175
|
-
// if (response?.status >= 400) {
|
176
|
-
// const copySourceError = response.headers.get(HeaderConstants.X_MS_CopySourceErrorCode);
|
177
|
-
// if (copySourceError !== undefined) {
|
178
|
-
// switch (copySourceError)
|
179
|
-
// {
|
180
|
-
// case "InternalError":
|
181
|
-
// case "OperationTimedOut":
|
182
|
-
// case "ServerBusy":
|
183
|
-
// return true;
|
184
|
-
// }
|
185
|
-
// }
|
186
|
-
// }
|
187
|
-
// }
|
188
|
-
if ((err === null || err === void 0 ? void 0 : err.code) === "PARSE_ERROR" && (err === null || err === void 0 ? void 0 : err.message.startsWith(`Error "Error: Unclosed root tag`))) {
|
189
|
-
logger.info("RetryPolicy: Incomplete XML response likely due to service timeout, will retry.");
|
190
|
-
return true;
|
191
|
-
}
|
192
|
-
return false;
|
193
|
-
}
|
194
|
-
/**
|
195
|
-
* Delay a calculated time between retries.
|
196
|
-
*
|
197
|
-
* @param isPrimaryRetry -
|
198
|
-
* @param attempt -
|
199
|
-
* @param abortSignal -
|
200
|
-
*/
|
201
|
-
async delay(isPrimaryRetry, attempt, abortSignal) {
|
202
|
-
let delayTimeInMs = 0;
|
203
|
-
if (isPrimaryRetry) {
|
204
|
-
switch (this.retryOptions.retryPolicyType) {
|
205
|
-
case StorageRetryPolicyType.EXPONENTIAL:
|
206
|
-
delayTimeInMs = Math.min((Math.pow(2, attempt - 1) - 1) * this.retryOptions.retryDelayInMs, this.retryOptions.maxRetryDelayInMs);
|
207
|
-
break;
|
208
|
-
case StorageRetryPolicyType.FIXED:
|
209
|
-
delayTimeInMs = this.retryOptions.retryDelayInMs;
|
210
|
-
break;
|
211
|
-
}
|
212
|
-
}
|
213
|
-
else {
|
214
|
-
delayTimeInMs = Math.random() * 1000;
|
215
|
-
}
|
216
|
-
logger.info(`RetryPolicy: Delay for ${delayTimeInMs}ms`);
|
217
|
-
return delay(delayTimeInMs, abortSignal, RETRY_ABORT_ERROR);
|
218
|
-
}
|
219
|
-
}
|
220
|
-
//# sourceMappingURL=StorageRetryPolicy.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"StorageRetryPolicy.js","sourceRoot":"","sources":["../../../../src/policies/StorageRetryPolicy.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { AbortSignalLike } from \"@azure/abort-controller\";\nimport { AbortError } from \"@azure/abort-controller\";\n\nimport type {\n RequestPolicy,\n RequestPolicyOptionsLike as RequestPolicyOptions,\n RequestPolicyFactory,\n WebResourceLike as WebResource,\n CompatResponse as HttpOperationResponse,\n} from \"@azure/core-http-compat\";\nimport { BaseRequestPolicy } from \"../../../storage-blob/src/policies/RequestPolicy\";\nimport type { RestError } from \"@azure/core-rest-pipeline\";\n\nimport type { StorageRetryOptions } from \"../StorageRetryPolicyFactory\";\nimport { URLConstants } from \"../utils/constants\";\nimport { delay, setURLParameter } from \"../utils/utils.common\";\nimport { logger } from \"../log\";\n\n/**\n * A factory method used to generated a RetryPolicy factory.\n *\n * @param retryOptions -\n */\nexport function NewRetryPolicyFactory(retryOptions?: StorageRetryOptions): RequestPolicyFactory {\n return {\n create: (nextPolicy: RequestPolicy, options: RequestPolicyOptions): StorageRetryPolicy => {\n return new StorageRetryPolicy(nextPolicy, options, retryOptions);\n },\n };\n}\n\n/**\n * RetryPolicy types.\n */\nexport enum StorageRetryPolicyType {\n /**\n * Exponential retry. Retry time delay grows exponentially.\n */\n EXPONENTIAL,\n /**\n * Linear retry. Retry time delay grows linearly.\n */\n FIXED,\n}\n\n// Default values of StorageRetryOptions\nconst DEFAULT_RETRY_OPTIONS: StorageRetryOptions = {\n maxRetryDelayInMs: 120 * 1000,\n maxTries: 4,\n retryDelayInMs: 4 * 1000,\n retryPolicyType: StorageRetryPolicyType.EXPONENTIAL,\n tryTimeoutInMs: undefined, // Use server side default timeout strategy\n};\n\nconst RETRY_ABORT_ERROR = new AbortError(\"The operation was aborted.\");\n\n/**\n * Retry policy with exponential retry and linear retry implemented.\n */\nexport class StorageRetryPolicy extends BaseRequestPolicy {\n /**\n * RetryOptions.\n */\n private readonly retryOptions: StorageRetryOptions;\n\n /**\n * Creates an instance of RetryPolicy.\n *\n * @param nextPolicy -\n * @param options -\n * @param retryOptions -\n */\n constructor(\n nextPolicy: RequestPolicy,\n options: RequestPolicyOptions,\n retryOptions: StorageRetryOptions = DEFAULT_RETRY_OPTIONS,\n ) {\n super(nextPolicy, options);\n\n // Initialize retry options\n this.retryOptions = {\n retryPolicyType: retryOptions.retryPolicyType\n ? retryOptions.retryPolicyType\n : DEFAULT_RETRY_OPTIONS.retryPolicyType,\n\n maxTries:\n retryOptions.maxTries && retryOptions.maxTries >= 1\n ? Math.floor(retryOptions.maxTries)\n : DEFAULT_RETRY_OPTIONS.maxTries,\n\n tryTimeoutInMs:\n retryOptions.tryTimeoutInMs && retryOptions.tryTimeoutInMs >= 0\n ? retryOptions.tryTimeoutInMs\n : DEFAULT_RETRY_OPTIONS.tryTimeoutInMs,\n\n retryDelayInMs:\n retryOptions.retryDelayInMs && retryOptions.retryDelayInMs >= 0\n ? Math.min(\n retryOptions.retryDelayInMs,\n retryOptions.maxRetryDelayInMs\n ? retryOptions.maxRetryDelayInMs\n : DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs!,\n )\n : DEFAULT_RETRY_OPTIONS.retryDelayInMs,\n\n maxRetryDelayInMs:\n retryOptions.maxRetryDelayInMs && retryOptions.maxRetryDelayInMs >= 0\n ? retryOptions.maxRetryDelayInMs\n : DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs,\n };\n }\n\n /**\n * Sends request.\n *\n * @param request -\n */\n public async sendRequest(request: WebResource): Promise<HttpOperationResponse> {\n return this.attemptSendRequest(request, false, 1);\n }\n\n /**\n * Decide and perform next retry. Won't mutate request parameter.\n *\n * @param request -\n * @param secondaryHas404 - If attempt was against the secondary & it returned a StatusNotFound (404), then\n * the resource was not found. This may be due to replication delay. So, in this\n * case, we'll never try the secondary again for this operation.\n * @param attempt - How many retries has been attempted to performed, starting from 1, which includes\n * the attempt will be performed by this method call.\n */\n protected async attemptSendRequest(\n request: WebResource,\n secondaryHas404: boolean,\n attempt: number,\n ): Promise<HttpOperationResponse> {\n const newRequest: WebResource = request.clone();\n\n const isPrimaryRetry = true;\n\n // Set the server-side timeout query parameter \"timeout=[seconds]\"\n if (this.retryOptions.tryTimeoutInMs) {\n newRequest.url = setURLParameter(\n newRequest.url,\n URLConstants.Parameters.TIMEOUT,\n Math.floor(this.retryOptions.tryTimeoutInMs! / 1000).toString(),\n );\n }\n\n let response: HttpOperationResponse | undefined;\n try {\n logger.info(`RetryPolicy: =====> Try=${attempt} ${isPrimaryRetry ? \"Primary\" : \"Secondary\"}`);\n response = await this._nextPolicy.sendRequest(newRequest);\n if (!this.shouldRetry(isPrimaryRetry, attempt, response)) {\n return response;\n }\n\n secondaryHas404 = secondaryHas404 || (!isPrimaryRetry && response.status === 404);\n } catch (err: any) {\n logger.error(`RetryPolicy: Caught error, message: ${err.message}, code: ${err.code}`);\n if (!this.shouldRetry(isPrimaryRetry, attempt, response, err)) {\n throw err;\n }\n }\n\n await this.delay(isPrimaryRetry, attempt, request.abortSignal);\n return this.attemptSendRequest(request, secondaryHas404, ++attempt);\n }\n\n /**\n * Decide whether to retry according to last HTTP response and retry counters.\n *\n * @param isPrimaryRetry -\n * @param attempt -\n * @param response -\n * @param err -\n */\n protected shouldRetry(\n isPrimaryRetry: boolean,\n attempt: number,\n response?: HttpOperationResponse,\n err?: RestError,\n ): boolean {\n if (attempt >= this.retryOptions.maxTries!) {\n logger.info(\n `RetryPolicy: Attempt(s) ${attempt} >= maxTries ${this.retryOptions\n .maxTries!}, no further try.`,\n );\n return false;\n }\n\n // Handle network failures, you may need to customize the list when you implement\n // your own http client\n const retriableErrors = [\n \"ETIMEDOUT\",\n \"ESOCKETTIMEDOUT\",\n \"ECONNREFUSED\",\n \"ECONNRESET\",\n \"ENOENT\",\n \"ENOTFOUND\",\n \"TIMEOUT\",\n \"EPIPE\",\n \"REQUEST_SEND_ERROR\", // For default xhr based http client provided in ms-rest-js\n ];\n if (err) {\n for (const retriableError of retriableErrors) {\n if (\n err.name.toUpperCase().includes(retriableError) ||\n err.message.toUpperCase().includes(retriableError) ||\n (err.code && err.code.toString().toUpperCase() === retriableError)\n ) {\n logger.info(`RetryPolicy: Network error ${retriableError} found, will retry.`);\n return true;\n }\n }\n }\n\n // If attempt was against the secondary & it returned a StatusNotFound (404), then\n // the resource was not found. This may be due to replication delay. So, in this\n // case, we'll never try the secondary again for this operation.\n if (response || err) {\n const statusCode = response ? response.status : err ? err.statusCode : 0;\n if (!isPrimaryRetry && statusCode === 404) {\n logger.info(`RetryPolicy: Secondary access with 404, will retry.`);\n return true;\n }\n\n // Server internal error or server timeout\n if (statusCode === 503 || statusCode === 500) {\n logger.info(`RetryPolicy: Will retry for status code ${statusCode}.`);\n return true;\n }\n }\n\n // [Copy source error code] Feature is pending on service side, skip retry on copy source error for now.\n // if (response) {\n // // Retry select Copy Source Error Codes.\n // if (response?.status >= 400) {\n // const copySourceError = response.headers.get(HeaderConstants.X_MS_CopySourceErrorCode);\n // if (copySourceError !== undefined) {\n // switch (copySourceError)\n // {\n // case \"InternalError\":\n // case \"OperationTimedOut\":\n // case \"ServerBusy\":\n // return true;\n // }\n // }\n // }\n // }\n\n if (err?.code === \"PARSE_ERROR\" && err?.message.startsWith(`Error \"Error: Unclosed root tag`)) {\n logger.info(\n \"RetryPolicy: Incomplete XML response likely due to service timeout, will retry.\",\n );\n return true;\n }\n\n return false;\n }\n\n /**\n * Delay a calculated time between retries.\n *\n * @param isPrimaryRetry -\n * @param attempt -\n * @param abortSignal -\n */\n private async delay(isPrimaryRetry: boolean, attempt: number, abortSignal?: AbortSignalLike) {\n let delayTimeInMs: number = 0;\n\n if (isPrimaryRetry) {\n switch (this.retryOptions.retryPolicyType) {\n case StorageRetryPolicyType.EXPONENTIAL:\n delayTimeInMs = Math.min(\n (Math.pow(2, attempt - 1) - 1) * this.retryOptions.retryDelayInMs!,\n this.retryOptions.maxRetryDelayInMs!,\n );\n break;\n case StorageRetryPolicyType.FIXED:\n delayTimeInMs = this.retryOptions.retryDelayInMs!;\n break;\n }\n } else {\n delayTimeInMs = Math.random() * 1000;\n }\n\n logger.info(`RetryPolicy: Delay for ${delayTimeInMs}ms`);\n return delay(delayTimeInMs, abortSignal, RETRY_ABORT_ERROR);\n }\n}\n"]}
|
@@ -1,176 +0,0 @@
|
|
1
|
-
// Copyright (c) Microsoft Corporation.
|
2
|
-
// Licensed under the MIT License.
|
3
|
-
import { AbortError } from "@azure/abort-controller";
|
4
|
-
import { isRestError, RestError } from "@azure/core-rest-pipeline";
|
5
|
-
import { getErrorMessage } from "@azure/core-util";
|
6
|
-
import { URLConstants } from "../utils/constants";
|
7
|
-
import { delay, setURLParameter } from "../utils/utils.common";
|
8
|
-
import { logger } from "../log";
|
9
|
-
/**
|
10
|
-
* Name of the {@link storageRetryPolicy}
|
11
|
-
*/
|
12
|
-
export const storageRetryPolicyName = "storageRetryPolicy";
|
13
|
-
/**
|
14
|
-
* RetryPolicy types.
|
15
|
-
*/
|
16
|
-
export var StorageRetryPolicyType;
|
17
|
-
(function (StorageRetryPolicyType) {
|
18
|
-
/**
|
19
|
-
* Exponential retry. Retry time delay grows exponentially.
|
20
|
-
*/
|
21
|
-
StorageRetryPolicyType[StorageRetryPolicyType["EXPONENTIAL"] = 0] = "EXPONENTIAL";
|
22
|
-
/**
|
23
|
-
* Linear retry. Retry time delay grows linearly.
|
24
|
-
*/
|
25
|
-
StorageRetryPolicyType[StorageRetryPolicyType["FIXED"] = 1] = "FIXED";
|
26
|
-
})(StorageRetryPolicyType || (StorageRetryPolicyType = {}));
|
27
|
-
// Default values of StorageRetryOptions
|
28
|
-
const DEFAULT_RETRY_OPTIONS = {
|
29
|
-
maxRetryDelayInMs: 120 * 1000,
|
30
|
-
maxTries: 4,
|
31
|
-
retryDelayInMs: 4 * 1000,
|
32
|
-
retryPolicyType: StorageRetryPolicyType.EXPONENTIAL,
|
33
|
-
secondaryHost: "",
|
34
|
-
tryTimeoutInMs: undefined, // Use server side default timeout strategy
|
35
|
-
};
|
36
|
-
const retriableErrors = [
|
37
|
-
"ETIMEDOUT",
|
38
|
-
"ESOCKETTIMEDOUT",
|
39
|
-
"ECONNREFUSED",
|
40
|
-
"ECONNRESET",
|
41
|
-
"ENOENT",
|
42
|
-
"ENOTFOUND",
|
43
|
-
"TIMEOUT",
|
44
|
-
"EPIPE",
|
45
|
-
"REQUEST_SEND_ERROR",
|
46
|
-
];
|
47
|
-
const RETRY_ABORT_ERROR = new AbortError("The operation was aborted.");
|
48
|
-
/**
|
49
|
-
* Retry policy with exponential retry and linear retry implemented.
|
50
|
-
*/
|
51
|
-
export function storageRetryPolicy(options = {}) {
|
52
|
-
var _a, _b, _c, _d, _e;
|
53
|
-
const retryPolicyType = (_a = options.retryPolicyType) !== null && _a !== void 0 ? _a : DEFAULT_RETRY_OPTIONS.retryPolicyType;
|
54
|
-
const maxTries = (_b = options.maxTries) !== null && _b !== void 0 ? _b : DEFAULT_RETRY_OPTIONS.maxTries;
|
55
|
-
const retryDelayInMs = (_c = options.retryDelayInMs) !== null && _c !== void 0 ? _c : DEFAULT_RETRY_OPTIONS.retryDelayInMs;
|
56
|
-
const maxRetryDelayInMs = (_d = options.maxRetryDelayInMs) !== null && _d !== void 0 ? _d : DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs;
|
57
|
-
const tryTimeoutInMs = (_e = options.tryTimeoutInMs) !== null && _e !== void 0 ? _e : DEFAULT_RETRY_OPTIONS.tryTimeoutInMs;
|
58
|
-
function shouldRetry({ isPrimaryRetry, attempt, response, error, }) {
|
59
|
-
var _a, _b;
|
60
|
-
if (attempt >= maxTries) {
|
61
|
-
logger.info(`RetryPolicy: Attempt(s) ${attempt} >= maxTries ${maxTries}, no further try.`);
|
62
|
-
return false;
|
63
|
-
}
|
64
|
-
if (error) {
|
65
|
-
for (const retriableError of retriableErrors) {
|
66
|
-
if (error.name.toUpperCase().includes(retriableError) ||
|
67
|
-
error.message.toUpperCase().includes(retriableError) ||
|
68
|
-
(error.code && error.code.toString().toUpperCase() === retriableError)) {
|
69
|
-
logger.info(`RetryPolicy: Network error ${retriableError} found, will retry.`);
|
70
|
-
return true;
|
71
|
-
}
|
72
|
-
}
|
73
|
-
if ((error === null || error === void 0 ? void 0 : error.code) === "PARSE_ERROR" &&
|
74
|
-
(error === null || error === void 0 ? void 0 : error.message.startsWith(`Error "Error: Unclosed root tag`))) {
|
75
|
-
logger.info("RetryPolicy: Incomplete XML response likely due to service timeout, will retry.");
|
76
|
-
return true;
|
77
|
-
}
|
78
|
-
}
|
79
|
-
// If attempt was against the secondary & it returned a StatusNotFound (404), then
|
80
|
-
// the resource was not found. This may be due to replication delay. So, in this
|
81
|
-
// case, we'll never try the secondary again for this operation.
|
82
|
-
if (response || error) {
|
83
|
-
const statusCode = (_b = (_a = response === null || response === void 0 ? void 0 : response.status) !== null && _a !== void 0 ? _a : error === null || error === void 0 ? void 0 : error.statusCode) !== null && _b !== void 0 ? _b : 0;
|
84
|
-
if (!isPrimaryRetry && statusCode === 404) {
|
85
|
-
logger.info(`RetryPolicy: Secondary access with 404, will retry.`);
|
86
|
-
return true;
|
87
|
-
}
|
88
|
-
// Server internal error or server timeout
|
89
|
-
if (statusCode === 503 || statusCode === 500) {
|
90
|
-
logger.info(`RetryPolicy: Will retry for status code ${statusCode}.`);
|
91
|
-
return true;
|
92
|
-
}
|
93
|
-
}
|
94
|
-
// [Copy source error code] Feature is pending on service side, skip retry on copy source error for now.
|
95
|
-
// if (response) {
|
96
|
-
// // Retry select Copy Source Error Codes.
|
97
|
-
// if (response?.status >= 400) {
|
98
|
-
// const copySourceError = response.headers.get(HeaderConstants.X_MS_CopySourceErrorCode);
|
99
|
-
// if (copySourceError !== undefined) {
|
100
|
-
// switch (copySourceError)
|
101
|
-
// {
|
102
|
-
// case "InternalError":
|
103
|
-
// case "OperationTimedOut":
|
104
|
-
// case "ServerBusy":
|
105
|
-
// return true;
|
106
|
-
// }
|
107
|
-
// }
|
108
|
-
// }
|
109
|
-
// }
|
110
|
-
return false;
|
111
|
-
}
|
112
|
-
function calculateDelay(isPrimaryRetry, attempt) {
|
113
|
-
let delayTimeInMs = 0;
|
114
|
-
if (isPrimaryRetry) {
|
115
|
-
switch (retryPolicyType) {
|
116
|
-
case StorageRetryPolicyType.EXPONENTIAL:
|
117
|
-
delayTimeInMs = Math.min((Math.pow(2, attempt - 1) - 1) * retryDelayInMs, maxRetryDelayInMs);
|
118
|
-
break;
|
119
|
-
case StorageRetryPolicyType.FIXED:
|
120
|
-
delayTimeInMs = retryDelayInMs;
|
121
|
-
break;
|
122
|
-
}
|
123
|
-
}
|
124
|
-
else {
|
125
|
-
delayTimeInMs = Math.random() * 1000;
|
126
|
-
}
|
127
|
-
logger.info(`RetryPolicy: Delay for ${delayTimeInMs}ms`);
|
128
|
-
return delayTimeInMs;
|
129
|
-
}
|
130
|
-
return {
|
131
|
-
name: storageRetryPolicyName,
|
132
|
-
async sendRequest(request, next) {
|
133
|
-
// Set the server-side timeout query parameter "timeout=[seconds]"
|
134
|
-
if (tryTimeoutInMs) {
|
135
|
-
request.url = setURLParameter(request.url, URLConstants.Parameters.TIMEOUT, String(Math.floor(tryTimeoutInMs / 1000)));
|
136
|
-
}
|
137
|
-
const primaryUrl = request.url;
|
138
|
-
let secondaryHas404 = false;
|
139
|
-
let attempt = 1;
|
140
|
-
let retryAgain = true;
|
141
|
-
let response;
|
142
|
-
let error;
|
143
|
-
while (retryAgain) {
|
144
|
-
const isPrimaryRetry = true;
|
145
|
-
request.url = primaryUrl;
|
146
|
-
response = undefined;
|
147
|
-
error = undefined;
|
148
|
-
try {
|
149
|
-
logger.info(`RetryPolicy: =====> Try=${attempt} ${isPrimaryRetry ? "Primary" : "Secondary"}`);
|
150
|
-
response = await next(request);
|
151
|
-
secondaryHas404 = secondaryHas404 || (!isPrimaryRetry && response.status === 404);
|
152
|
-
}
|
153
|
-
catch (e) {
|
154
|
-
if (isRestError(e)) {
|
155
|
-
logger.error(`RetryPolicy: Caught error, message: ${e.message}, code: ${e.code}`);
|
156
|
-
error = e;
|
157
|
-
}
|
158
|
-
else {
|
159
|
-
logger.error(`RetryPolicy: Caught error, message: ${getErrorMessage(e)}`);
|
160
|
-
throw e;
|
161
|
-
}
|
162
|
-
}
|
163
|
-
retryAgain = shouldRetry({ isPrimaryRetry, attempt, response, error });
|
164
|
-
if (retryAgain) {
|
165
|
-
await delay(calculateDelay(isPrimaryRetry, attempt), request.abortSignal, RETRY_ABORT_ERROR);
|
166
|
-
}
|
167
|
-
attempt++;
|
168
|
-
}
|
169
|
-
if (response) {
|
170
|
-
return response;
|
171
|
-
}
|
172
|
-
throw error !== null && error !== void 0 ? error : new RestError("RetryPolicy failed without known error.");
|
173
|
-
},
|
174
|
-
};
|
175
|
-
}
|
176
|
-
//# sourceMappingURL=StorageRetryPolicyV2.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"StorageRetryPolicyV2.js","sourceRoot":"","sources":["../../../../src/policies/StorageRetryPolicyV2.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { AbortError } from \"@azure/abort-controller\";\nimport type {\n PipelinePolicy,\n PipelineRequest,\n SendRequest,\n PipelineResponse,\n} from \"@azure/core-rest-pipeline\";\nimport { isRestError, RestError } from \"@azure/core-rest-pipeline\";\nimport { getErrorMessage } from \"@azure/core-util\";\nimport type { StorageRetryOptions } from \"../StorageRetryPolicyFactory\";\nimport { URLConstants } from \"../utils/constants\";\nimport { delay, setURLParameter } from \"../utils/utils.common\";\nimport { logger } from \"../log\";\n\n/**\n * Name of the {@link storageRetryPolicy}\n */\nexport const storageRetryPolicyName = \"storageRetryPolicy\";\n\n/**\n * RetryPolicy types.\n */\nexport enum StorageRetryPolicyType {\n /**\n * Exponential retry. Retry time delay grows exponentially.\n */\n EXPONENTIAL,\n /**\n * Linear retry. Retry time delay grows linearly.\n */\n FIXED,\n}\n\n// Default values of StorageRetryOptions\nconst DEFAULT_RETRY_OPTIONS = {\n maxRetryDelayInMs: 120 * 1000,\n maxTries: 4,\n retryDelayInMs: 4 * 1000,\n retryPolicyType: StorageRetryPolicyType.EXPONENTIAL,\n secondaryHost: \"\",\n tryTimeoutInMs: undefined, // Use server side default timeout strategy\n} as const;\n\nconst retriableErrors = [\n \"ETIMEDOUT\",\n \"ESOCKETTIMEDOUT\",\n \"ECONNREFUSED\",\n \"ECONNRESET\",\n \"ENOENT\",\n \"ENOTFOUND\",\n \"TIMEOUT\",\n \"EPIPE\",\n \"REQUEST_SEND_ERROR\",\n] as const;\n\nconst RETRY_ABORT_ERROR = new AbortError(\"The operation was aborted.\");\n\n/**\n * Retry policy with exponential retry and linear retry implemented.\n */\nexport function storageRetryPolicy(options: StorageRetryOptions = {}): PipelinePolicy {\n const retryPolicyType = options.retryPolicyType ?? DEFAULT_RETRY_OPTIONS.retryPolicyType;\n const maxTries = options.maxTries ?? DEFAULT_RETRY_OPTIONS.maxTries;\n const retryDelayInMs = options.retryDelayInMs ?? DEFAULT_RETRY_OPTIONS.retryDelayInMs;\n const maxRetryDelayInMs = options.maxRetryDelayInMs ?? DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs;\n const tryTimeoutInMs = options.tryTimeoutInMs ?? DEFAULT_RETRY_OPTIONS.tryTimeoutInMs;\n\n function shouldRetry({\n isPrimaryRetry,\n attempt,\n response,\n error,\n }: {\n isPrimaryRetry: boolean;\n attempt: number;\n response?: PipelineResponse;\n error?: RestError;\n }): boolean {\n if (attempt >= maxTries) {\n logger.info(`RetryPolicy: Attempt(s) ${attempt} >= maxTries ${maxTries}, no further try.`);\n return false;\n }\n if (error) {\n for (const retriableError of retriableErrors) {\n if (\n error.name.toUpperCase().includes(retriableError) ||\n error.message.toUpperCase().includes(retriableError) ||\n (error.code && error.code.toString().toUpperCase() === retriableError)\n ) {\n logger.info(`RetryPolicy: Network error ${retriableError} found, will retry.`);\n return true;\n }\n }\n if (\n error?.code === \"PARSE_ERROR\" &&\n error?.message.startsWith(`Error \"Error: Unclosed root tag`)\n ) {\n logger.info(\n \"RetryPolicy: Incomplete XML response likely due to service timeout, will retry.\",\n );\n return true;\n }\n }\n // If attempt was against the secondary & it returned a StatusNotFound (404), then\n // the resource was not found. This may be due to replication delay. So, in this\n // case, we'll never try the secondary again for this operation.\n if (response || error) {\n const statusCode = response?.status ?? error?.statusCode ?? 0;\n if (!isPrimaryRetry && statusCode === 404) {\n logger.info(`RetryPolicy: Secondary access with 404, will retry.`);\n return true;\n }\n\n // Server internal error or server timeout\n if (statusCode === 503 || statusCode === 500) {\n logger.info(`RetryPolicy: Will retry for status code ${statusCode}.`);\n return true;\n }\n }\n\n // [Copy source error code] Feature is pending on service side, skip retry on copy source error for now.\n // if (response) {\n // // Retry select Copy Source Error Codes.\n // if (response?.status >= 400) {\n // const copySourceError = response.headers.get(HeaderConstants.X_MS_CopySourceErrorCode);\n // if (copySourceError !== undefined) {\n // switch (copySourceError)\n // {\n // case \"InternalError\":\n // case \"OperationTimedOut\":\n // case \"ServerBusy\":\n // return true;\n // }\n // }\n // }\n // }\n\n return false;\n }\n function calculateDelay(isPrimaryRetry: boolean, attempt: number): number {\n let delayTimeInMs = 0;\n\n if (isPrimaryRetry) {\n switch (retryPolicyType) {\n case StorageRetryPolicyType.EXPONENTIAL:\n delayTimeInMs = Math.min(\n (Math.pow(2, attempt - 1) - 1) * retryDelayInMs,\n maxRetryDelayInMs,\n );\n break;\n case StorageRetryPolicyType.FIXED:\n delayTimeInMs = retryDelayInMs;\n break;\n }\n } else {\n delayTimeInMs = Math.random() * 1000;\n }\n\n logger.info(`RetryPolicy: Delay for ${delayTimeInMs}ms`);\n return delayTimeInMs;\n }\n return {\n name: storageRetryPolicyName,\n async sendRequest(request: PipelineRequest, next: SendRequest): Promise<PipelineResponse> {\n // Set the server-side timeout query parameter \"timeout=[seconds]\"\n if (tryTimeoutInMs) {\n request.url = setURLParameter(\n request.url,\n URLConstants.Parameters.TIMEOUT,\n String(Math.floor(tryTimeoutInMs / 1000)),\n );\n }\n const primaryUrl = request.url;\n let secondaryHas404 = false;\n let attempt = 1;\n let retryAgain = true;\n let response: PipelineResponse | undefined;\n let error: RestError | undefined;\n while (retryAgain) {\n const isPrimaryRetry: boolean = true;\n request.url = primaryUrl;\n response = undefined;\n error = undefined;\n try {\n logger.info(\n `RetryPolicy: =====> Try=${attempt} ${isPrimaryRetry ? \"Primary\" : \"Secondary\"}`,\n );\n response = await next(request);\n secondaryHas404 = secondaryHas404 || (!isPrimaryRetry && response.status === 404);\n } catch (e: unknown) {\n if (isRestError(e)) {\n logger.error(`RetryPolicy: Caught error, message: ${e.message}, code: ${e.code}`);\n error = e;\n } else {\n logger.error(`RetryPolicy: Caught error, message: ${getErrorMessage(e)}`);\n throw e;\n }\n }\n retryAgain = shouldRetry({ isPrimaryRetry, attempt, response, error });\n if (retryAgain) {\n await delay(\n calculateDelay(isPrimaryRetry, attempt),\n request.abortSignal,\n RETRY_ABORT_ERROR,\n );\n }\n attempt++;\n }\n if (response) {\n return response;\n }\n throw error ?? new RestError(\"RetryPolicy failed without known error.\");\n },\n };\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"Batch.js","sourceRoot":"","sources":["../../../../src/utils/Batch.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,8FAA8F;AAC9F,mCAAmC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAOtC;;GAEG;AACH,IAAK,WAGJ;AAHD,WAAK,WAAW;IACd,6CAAI,CAAA;IACJ,+CAAK,CAAA;AACP,CAAC,EAHI,WAAW,KAAX,WAAW,QAGf;AAED;;;;GAIG;AACH,MAAM,OAAO,KAAK;IAqChB;;;OAGG;IACH,YAAmB,cAAsB,CAAC;QAnC1C;;WAEG;QACK,YAAO,GAAW,CAAC,CAAC;QAE5B;;WAEG;QACK,cAAS,GAAW,CAAC,CAAC;QAE9B;;WAEG;QACK,WAAM,GAAW,CAAC,CAAC;QAE3B;;WAEG;QACK,eAAU,GAAgB,EAAE,CAAC;QAErC;;;WAGG;QACK,UAAK,GAAgB,WAAW,CAAC,IAAI,CAAC;QAY5C,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;YACpB,MAAM,IAAI,UAAU,CAAC,mCAAmC,CAAC,CAAC;QAC5D,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,OAAO,GAAG,IAAI,YAAY,EAAE,CAAC;IACpC,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,SAAoB;QACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YAC9B,IAAI,CAAC;gBACH,IAAI,CAAC,OAAO,EAAE,CAAC;gBACf,MAAM,SAAS,EAAE,CAAC;gBAClB,IAAI,CAAC,OAAO,EAAE,CAAC;gBACf,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC;YAAC,OAAO,KAAU,EAAE,CAAC;gBACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YACpC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,EAAE;QACb,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACjC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;QAC3B,CAAC;QAED,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3C,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YAEnC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBACjC,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC;gBAC/B,MAAM,CAAC,KAAK,CAAC,CAAC;YAChB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACK,aAAa;QACnB,IAAI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;YACzC,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACxC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACK,eAAe;QACrB,IAAI,IAAI,CAAC,KAAK,KAAK,WAAW,CAAC,KAAK,EAAE,CAAC;YACrC,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;YAC7C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC5B,OAAO;QACT,CAAC;QAED,OAAO,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YACvC,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YACvC,IAAI,SAAS,EAAE,CAAC;gBACd,SAAS,EAAE,CAAC;YACd,CAAC;iBAAM,CAAC;gBACN,OAAO;YACT,CAAC;QACH,CAAC;IACH,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n// In browser, during webpack or browserify bundling, this module will be replaced by 'events'\n// https://github.com/Gozala/events\nimport { EventEmitter } from \"events\";\n\n/**\n * Operation is an async function to be executed and managed by Batch.\n */\nexport declare type Operation = () => Promise<any>;\n\n/**\n * States for Batch.\n */\nenum BatchStates {\n Good,\n Error,\n}\n\n/**\n * Batch provides basic parallel execution with concurrency limits.\n * Will stop execute left operations when one of the executed operation throws an error.\n * But Batch cannot cancel ongoing operations, you need to cancel them by yourself.\n */\nexport class Batch {\n /**\n * Concurrency. Must be lager than 0.\n */\n private concurrency: number;\n\n /**\n * Number of active operations under execution.\n */\n private actives: number = 0;\n\n /**\n * Number of completed operations under execution.\n */\n private completed: number = 0;\n\n /**\n * Offset of next operation to be executed.\n */\n private offset: number = 0;\n\n /**\n * Operation array to be executed.\n */\n private operations: Operation[] = [];\n\n /**\n * States of Batch. When an error happens, state will turn into error.\n * Batch will stop execute left operations.\n */\n private state: BatchStates = BatchStates.Good;\n\n /**\n * A private emitter used to pass events inside this class.\n */\n private emitter: EventEmitter;\n\n /**\n * Creates an instance of Batch.\n * @param concurrency -\n */\n public constructor(concurrency: number = 5) {\n if (concurrency < 1) {\n throw new RangeError(\"concurrency must be larger than 0\");\n }\n this.concurrency = concurrency;\n this.emitter = new EventEmitter();\n }\n\n /**\n * Add a operation into queue.\n *\n * @param operation -\n */\n public addOperation(operation: Operation): void {\n this.operations.push(async () => {\n try {\n this.actives++;\n await operation();\n this.actives--;\n this.completed++;\n this.parallelExecute();\n } catch (error: any) {\n this.emitter.emit(\"error\", error);\n }\n });\n }\n\n /**\n * Start execute operations in the queue.\n *\n */\n public async do(): Promise<void> {\n if (this.operations.length === 0) {\n return Promise.resolve();\n }\n\n this.parallelExecute();\n\n return new Promise<void>((resolve, reject) => {\n this.emitter.on(\"finish\", resolve);\n\n this.emitter.on(\"error\", (error) => {\n this.state = BatchStates.Error;\n reject(error);\n });\n });\n }\n\n /**\n * Get next operation to be executed. Return null when reaching ends.\n *\n */\n private nextOperation(): Operation | null {\n if (this.offset < this.operations.length) {\n return this.operations[this.offset++];\n }\n return null;\n }\n\n /**\n * Start execute operations. One one the most important difference between\n * this method with do() is that do() wraps as an sync method.\n *\n */\n private parallelExecute(): void {\n if (this.state === BatchStates.Error) {\n return;\n }\n\n if (this.completed >= this.operations.length) {\n this.emitter.emit(\"finish\");\n return;\n }\n\n while (this.actives < this.concurrency) {\n const operation = this.nextOperation();\n if (operation) {\n operation();\n } else {\n return;\n }\n }\n }\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"BufferScheduler.js","sourceRoot":"","sources":["../../../../src/utils/BufferScheduler.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { EventEmitter } from \"events\";\nimport type { Readable } from \"stream\";\n\n/**\n * OutgoingHandler is an async function triggered by BufferScheduler.\n */\nexport declare type OutgoingHandler = (buffer: Buffer, offset?: number) => Promise<any>;\n\n/**\n * This class accepts a Node.js Readable stream as input, and keeps reading data\n * from the stream into the internal buffer structure, until it reaches maxBuffers.\n * Every available buffer will try to trigger outgoingHandler.\n *\n * The internal buffer structure includes an incoming buffer array, and a outgoing\n * buffer array. The incoming buffer array includes the \"empty\" buffers can be filled\n * with new incoming data. The outgoing array includes the filled buffers to be\n * handled by outgoingHandler. Every above buffer size is defined by parameter bufferSize.\n *\n * NUM_OF_ALL_BUFFERS = BUFFERS_IN_INCOMING + BUFFERS_IN_OUTGOING + BUFFERS_UNDER_HANDLING\n *\n * NUM_OF_ALL_BUFFERS lesser than or equal to maxBuffers\n *\n * PERFORMANCE IMPROVEMENT TIPS:\n * 1. Input stream highWaterMark is better to set a same value with bufferSize\n * parameter, which will avoid Buffer.concat() operations.\n * 2. Concurrency should set a smaller value than maxBuffers, which is helpful to\n * reduce the possibility when a outgoing handler waits for the stream data.\n * in this situation, outgoing handlers are blocked.\n * Outgoing queue shouldn't be empty.\n */\nexport class BufferScheduler {\n /**\n * Size of buffers in incoming and outgoing queues. This class will try to align\n * data read from Readable stream into buffer chunks with bufferSize defined.\n */\n private readonly bufferSize: number;\n\n /**\n * How many buffers can be created or maintained.\n */\n private readonly maxBuffers: number;\n\n /**\n * A Node.js Readable stream.\n */\n private readonly readable: Readable;\n\n /**\n * OutgoingHandler is an async function triggered by BufferScheduler when there\n * are available buffers in outgoing array.\n */\n private readonly outgoingHandler: OutgoingHandler;\n\n /**\n * An internal event emitter.\n */\n private readonly emitter: EventEmitter = new EventEmitter();\n\n /**\n * Concurrency of executing outgoingHandlers. (0 lesser than concurrency lesser than or equal to maxBuffers)\n */\n private readonly concurrency: number;\n\n /**\n * An internal offset marker to track data offset in bytes of next outgoingHandler.\n */\n private offset: number = 0;\n\n /**\n * An internal marker to track whether stream is end.\n */\n private isStreamEnd: boolean = false;\n\n /**\n * An internal marker to track whether stream or outgoingHandler returns error.\n */\n private isError: boolean = false;\n\n /**\n * How many handlers are executing.\n */\n private executingOutgoingHandlers: number = 0;\n\n /**\n * Encoding of the input Readable stream which has string data type instead of Buffer.\n */\n private encoding?: BufferEncoding;\n\n /**\n * How many buffers have been allocated.\n */\n private numBuffers: number = 0;\n\n /**\n * Because this class doesn't know how much data every time stream pops, which\n * is defined by highWaterMarker of the stream. So BufferScheduler will cache\n * data received from the stream, when data in unresolvedDataArray exceeds the\n * blockSize defined, it will try to concat a blockSize of buffer, fill into available\n * buffers from incoming and push to outgoing array.\n */\n private unresolvedDataArray: Buffer[] = [];\n\n /**\n * How much data consisted in unresolvedDataArray.\n */\n private unresolvedLength: number = 0;\n\n /**\n * The array includes all the available buffers can be used to fill data from stream.\n */\n private incoming: Buffer[] = [];\n\n /**\n * The array (queue) includes all the buffers filled from stream data.\n */\n private outgoing: Buffer[] = [];\n\n /**\n * Creates an instance of BufferScheduler.\n *\n * @param readable - A Node.js Readable stream\n * @param bufferSize - Buffer size of every maintained buffer\n * @param maxBuffers - How many buffers can be allocated\n * @param outgoingHandler - An async function scheduled to be\n * triggered when a buffer fully filled\n * with stream data\n * @param concurrency - Concurrency of executing outgoingHandlers (greater than 0)\n * @param encoding - [Optional] Encoding of Readable stream when it's a string stream\n */\n constructor(\n readable: Readable,\n bufferSize: number,\n maxBuffers: number,\n outgoingHandler: OutgoingHandler,\n concurrency: number,\n encoding?: BufferEncoding,\n ) {\n if (bufferSize <= 0) {\n throw new RangeError(`bufferSize must be larger than 0, current is ${bufferSize}`);\n }\n\n if (maxBuffers <= 0) {\n throw new RangeError(`maxBuffers must be larger than 0, current is ${maxBuffers}`);\n }\n\n if (concurrency <= 0) {\n throw new RangeError(`concurrency must be larger than 0, current is ${concurrency}`);\n }\n\n this.bufferSize = bufferSize;\n this.maxBuffers = maxBuffers;\n this.readable = readable;\n this.outgoingHandler = outgoingHandler;\n this.concurrency = concurrency;\n this.encoding = encoding;\n }\n\n /**\n * Start the scheduler, will return error when stream of any of the outgoingHandlers\n * returns error.\n *\n */\n public async do(): Promise<void> {\n return new Promise<void>((resolve, reject) => {\n this.readable.on(\"data\", (data) => {\n data = typeof data === \"string\" ? Buffer.from(data, this.encoding) : data;\n this.appendUnresolvedData(data);\n\n if (!this.resolveData()) {\n this.readable.pause();\n }\n });\n\n this.readable.on(\"error\", (err) => {\n this.emitter.emit(\"error\", err);\n });\n\n this.readable.on(\"end\", () => {\n this.isStreamEnd = true;\n this.emitter.emit(\"checkEnd\");\n });\n\n this.emitter.on(\"error\", (err) => {\n this.isError = true;\n this.readable.pause();\n reject(err);\n });\n\n this.emitter.on(\"checkEnd\", () => {\n if (this.outgoing.length > 0) {\n this.triggerOutgoingHandlers();\n return;\n }\n\n if (this.isStreamEnd && this.executingOutgoingHandlers === 0) {\n if (this.unresolvedLength > 0 && this.unresolvedLength < this.bufferSize) {\n this.outgoingHandler(this.shiftBufferFromUnresolvedDataArray(), this.offset)\n .then(resolve)\n .catch(reject);\n } else if (this.unresolvedLength >= this.bufferSize) {\n return;\n } else {\n resolve();\n }\n }\n });\n });\n }\n\n /**\n * Insert a new data into unresolved array.\n *\n * @param data -\n */\n private appendUnresolvedData(data: Buffer) {\n this.unresolvedDataArray.push(data);\n this.unresolvedLength += data.length;\n }\n\n /**\n * Try to shift a buffer with size in blockSize. The buffer returned may be less\n * than blockSize when data in unresolvedDataArray is less than bufferSize.\n *\n */\n private shiftBufferFromUnresolvedDataArray(): Buffer {\n if (this.unresolvedLength >= this.bufferSize) {\n if (this.bufferSize === this.unresolvedDataArray[0].length) {\n this.unresolvedLength -= this.bufferSize;\n return this.unresolvedDataArray.shift()!;\n }\n\n // Lazy concat because Buffer.concat highly drops performance\n let merged = Buffer.concat(this.unresolvedDataArray, this.unresolvedLength);\n const buffer = merged.slice(0, this.bufferSize);\n merged = merged.slice(this.bufferSize);\n this.unresolvedDataArray = [merged];\n this.unresolvedLength -= buffer.length;\n return buffer;\n } else if (this.unresolvedLength > 0) {\n const merged = Buffer.concat(this.unresolvedDataArray, this.unresolvedLength);\n this.unresolvedDataArray = [];\n this.unresolvedLength = 0;\n return merged;\n } else {\n return Buffer.allocUnsafe(0);\n }\n }\n\n /**\n * Resolve data in unresolvedDataArray. For every buffer with size in blockSize\n * shifted, it will try to get (or allocate a buffer) from incoming, and fill it,\n * then push it into outgoing to be handled by outgoing handler.\n *\n * Return false when available buffers in incoming are not enough, else true.\n *\n * @returns Return false when buffers in incoming are not enough, else true.\n */\n private resolveData(): boolean {\n while (this.unresolvedLength >= this.bufferSize) {\n let buffer: Buffer;\n\n if (this.incoming.length > 0) {\n buffer = this.incoming.shift()!;\n } else {\n if (this.numBuffers < this.maxBuffers) {\n buffer = Buffer.allocUnsafe(this.bufferSize);\n this.numBuffers++;\n } else {\n // No available buffer, wait for buffer returned\n return false;\n }\n }\n\n buffer.fill(this.shiftBufferFromUnresolvedDataArray());\n this.outgoing.push(buffer);\n this.triggerOutgoingHandlers();\n }\n return true;\n }\n\n /**\n * Try to trigger a outgoing handler for every buffer in outgoing. Stop when\n * concurrency reaches.\n */\n private async triggerOutgoingHandlers() {\n let buffer: Buffer | undefined;\n do {\n if (this.executingOutgoingHandlers >= this.concurrency) {\n return;\n }\n\n buffer = this.outgoing.shift();\n if (buffer) {\n this.triggerOutgoingHandler(buffer);\n }\n } while (buffer);\n }\n\n /**\n * Trigger a outgoing handler for a buffer shifted from outgoing.\n *\n * @param buffer -\n */\n private async triggerOutgoingHandler(buffer: Buffer): Promise<any> {\n const bufferLength = buffer.length;\n\n this.executingOutgoingHandlers++;\n this.offset += bufferLength;\n\n try {\n await this.outgoingHandler(buffer, this.offset - bufferLength);\n } catch (err: any) {\n this.emitter.emit(\"error\", err);\n return;\n }\n\n this.executingOutgoingHandlers--;\n this.reuseBuffer(buffer);\n this.emitter.emit(\"checkEnd\");\n }\n\n /**\n * Return buffer used by outgoing handler into incoming.\n *\n * @param buffer -\n */\n private reuseBuffer(buffer: Buffer) {\n this.incoming.push(buffer);\n if (!this.isError && this.resolveData() && !this.isStreamEnd) {\n this.readable.resume();\n }\n }\n}\n"]}
|
@@ -1,119 +0,0 @@
|
|
1
|
-
// Copyright (c) Microsoft Corporation.
|
2
|
-
// Licensed under the MIT License.
|
3
|
-
import { AbortError } from "@azure/abort-controller";
|
4
|
-
import { Readable } from "stream";
|
5
|
-
/**
|
6
|
-
* ONLY AVAILABLE IN NODE.JS RUNTIME.
|
7
|
-
*
|
8
|
-
* A Node.js ReadableStream will internally retry when internal ReadableStream unexpected ends.
|
9
|
-
*/
|
10
|
-
export class RetriableReadableStream extends Readable {
|
11
|
-
/**
|
12
|
-
* Creates an instance of RetriableReadableStream.
|
13
|
-
*
|
14
|
-
* @param source - The current ReadableStream returned from getter
|
15
|
-
* @param getter - A method calling downloading request returning
|
16
|
-
* a new ReadableStream from specified offset
|
17
|
-
* @param offset - Offset position in original data source to read
|
18
|
-
* @param count - How much data in original data source to read
|
19
|
-
* @param options -
|
20
|
-
*/
|
21
|
-
constructor(source, getter, offset, count, options = {}) {
|
22
|
-
super();
|
23
|
-
this.retries = 0;
|
24
|
-
this.sourceDataHandler = (data) => {
|
25
|
-
if (this.options.doInjectErrorOnce) {
|
26
|
-
this.options.doInjectErrorOnce = undefined;
|
27
|
-
this.source.pause();
|
28
|
-
this.sourceErrorOrEndHandler();
|
29
|
-
this.source.destroy();
|
30
|
-
return;
|
31
|
-
}
|
32
|
-
// console.log(
|
33
|
-
// `Offset: ${this.offset}, Received ${data.length} from internal stream`
|
34
|
-
// );
|
35
|
-
this.offset += data.length;
|
36
|
-
if (this.onProgress) {
|
37
|
-
this.onProgress({ loadedBytes: this.offset - this.start });
|
38
|
-
}
|
39
|
-
if (!this.push(data)) {
|
40
|
-
this.source.pause();
|
41
|
-
}
|
42
|
-
};
|
43
|
-
this.sourceAbortedHandler = () => {
|
44
|
-
const abortError = new AbortError("The operation was aborted.");
|
45
|
-
this.destroy(abortError);
|
46
|
-
};
|
47
|
-
this.sourceErrorOrEndHandler = (err) => {
|
48
|
-
if (err && err.name === "AbortError") {
|
49
|
-
this.destroy(err);
|
50
|
-
return;
|
51
|
-
}
|
52
|
-
// console.log(
|
53
|
-
// `Source stream emits end or error, offset: ${
|
54
|
-
// this.offset
|
55
|
-
// }, dest end : ${this.end}`
|
56
|
-
// );
|
57
|
-
this.removeSourceEventHandlers();
|
58
|
-
if (this.offset - 1 === this.end) {
|
59
|
-
this.push(null);
|
60
|
-
}
|
61
|
-
else if (this.offset <= this.end) {
|
62
|
-
// console.log(
|
63
|
-
// `retries: ${this.retries}, max retries: ${this.maxRetries}`
|
64
|
-
// );
|
65
|
-
if (this.retries < this.maxRetryRequests) {
|
66
|
-
this.retries += 1;
|
67
|
-
this.getter(this.offset)
|
68
|
-
.then((newSource) => {
|
69
|
-
this.source = newSource;
|
70
|
-
this.setSourceEventHandlers();
|
71
|
-
return;
|
72
|
-
})
|
73
|
-
.catch((error) => {
|
74
|
-
this.destroy(error);
|
75
|
-
});
|
76
|
-
}
|
77
|
-
else {
|
78
|
-
this.destroy(new Error(`Data corruption failure: received less data than required and reached maxRetires limitation. Received data offset: ${this.offset - 1}, data needed offset: ${this.end}, retries: ${this.retries}, max retries: ${this.maxRetryRequests}`));
|
79
|
-
}
|
80
|
-
}
|
81
|
-
else {
|
82
|
-
this.destroy(new Error(`Data corruption failure: Received more data than original request, data needed offset is ${this.end}, received offset: ${this.offset - 1}`));
|
83
|
-
}
|
84
|
-
};
|
85
|
-
this.getter = getter;
|
86
|
-
this.source = source;
|
87
|
-
this.start = offset;
|
88
|
-
this.offset = offset;
|
89
|
-
this.end = offset + count - 1;
|
90
|
-
this.maxRetryRequests =
|
91
|
-
options.maxRetryRequests && options.maxRetryRequests >= 0 ? options.maxRetryRequests : 0;
|
92
|
-
this.onProgress = options.onProgress;
|
93
|
-
this.options = options;
|
94
|
-
this.setSourceEventHandlers();
|
95
|
-
}
|
96
|
-
_read() {
|
97
|
-
this.source.resume();
|
98
|
-
}
|
99
|
-
setSourceEventHandlers() {
|
100
|
-
this.source.on("data", this.sourceDataHandler);
|
101
|
-
this.source.on("end", this.sourceErrorOrEndHandler);
|
102
|
-
this.source.on("error", this.sourceErrorOrEndHandler);
|
103
|
-
// needed for Node14
|
104
|
-
this.source.on("aborted", this.sourceAbortedHandler);
|
105
|
-
}
|
106
|
-
removeSourceEventHandlers() {
|
107
|
-
this.source.removeListener("data", this.sourceDataHandler);
|
108
|
-
this.source.removeListener("end", this.sourceErrorOrEndHandler);
|
109
|
-
this.source.removeListener("error", this.sourceErrorOrEndHandler);
|
110
|
-
this.source.removeListener("aborted", this.sourceAbortedHandler);
|
111
|
-
}
|
112
|
-
_destroy(error, callback) {
|
113
|
-
// remove listener from source and release source
|
114
|
-
this.removeSourceEventHandlers();
|
115
|
-
this.source.destroy();
|
116
|
-
callback(error === null ? undefined : error);
|
117
|
-
}
|
118
|
-
}
|
119
|
-
//# sourceMappingURL=RetriableReadableStream.js.map
|