@azure/storage-blob 12.29.1 → 12.30.0-alpha.20251111.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (418) hide show
  1. package/dist/browser/BlobBatch.d.ts +1 -2
  2. package/dist/browser/BlobBatch.d.ts.map +1 -1
  3. package/dist/browser/BlobBatch.js +1 -3
  4. package/dist/browser/BlobBatch.js.map +1 -1
  5. package/dist/browser/BlobBatchClient.d.ts +1 -2
  6. package/dist/browser/BlobBatchClient.d.ts.map +1 -1
  7. package/dist/browser/BlobBatchClient.js +1 -1
  8. package/dist/browser/BlobBatchClient.js.map +1 -1
  9. package/dist/browser/BlobServiceClient.d.ts +1 -2
  10. package/dist/browser/BlobServiceClient.d.ts.map +1 -1
  11. package/dist/browser/BlobServiceClient.js +1 -2
  12. package/dist/browser/BlobServiceClient.js.map +1 -1
  13. package/dist/browser/Clients.d.ts +1 -2
  14. package/dist/browser/Clients.d.ts.map +1 -1
  15. package/dist/browser/Clients.js +1 -2
  16. package/dist/browser/Clients.js.map +1 -1
  17. package/dist/browser/ContainerClient.d.ts +1 -2
  18. package/dist/browser/ContainerClient.d.ts.map +1 -1
  19. package/dist/browser/ContainerClient.js +1 -2
  20. package/dist/browser/ContainerClient.js.map +1 -1
  21. package/dist/browser/Pipeline.d.ts +2 -3
  22. package/dist/browser/Pipeline.d.ts.map +1 -1
  23. package/dist/browser/Pipeline.js +1 -9
  24. package/dist/browser/Pipeline.js.map +1 -1
  25. package/dist/browser/StorageClient.d.ts +1 -2
  26. package/dist/browser/StorageClient.d.ts.map +1 -1
  27. package/dist/browser/StorageClient.js.map +1 -1
  28. package/dist/browser/index-browser.d.mts.map +1 -1
  29. package/dist/browser/index-browser.mjs.map +1 -1
  30. package/dist/browser/index.d.ts +1 -7
  31. package/dist/browser/index.js +2 -7
  32. package/dist/browser/sas/AccountSASSignatureValues.d.ts +1 -1
  33. package/dist/browser/sas/AccountSASSignatureValues.d.ts.map +1 -1
  34. package/dist/browser/sas/AccountSASSignatureValues.js.map +1 -1
  35. package/dist/browser/sas/BlobSASSignatureValues.d.ts +1 -1
  36. package/dist/browser/sas/BlobSASSignatureValues.d.ts.map +1 -1
  37. package/dist/browser/sas/BlobSASSignatureValues.js +1 -1
  38. package/dist/browser/sas/BlobSASSignatureValues.js.map +1 -1
  39. package/dist/browser/utils/constants.js +1 -1
  40. package/dist/browser/utils/constants.js.map +1 -1
  41. package/dist/commonjs/BlobBatch.d.ts +1 -2
  42. package/dist/commonjs/BlobBatch.d.ts.map +1 -1
  43. package/dist/commonjs/BlobBatch.js +7 -9
  44. package/dist/commonjs/BlobBatch.js.map +1 -1
  45. package/dist/commonjs/BlobBatchClient.d.ts +1 -2
  46. package/dist/commonjs/BlobBatchClient.d.ts.map +1 -1
  47. package/dist/commonjs/BlobBatchClient.js +2 -2
  48. package/dist/commonjs/BlobBatchClient.js.map +1 -1
  49. package/dist/commonjs/BlobServiceClient.d.ts +1 -2
  50. package/dist/commonjs/BlobServiceClient.d.ts.map +1 -1
  51. package/dist/commonjs/BlobServiceClient.js +8 -9
  52. package/dist/commonjs/BlobServiceClient.js.map +1 -1
  53. package/dist/commonjs/Clients.d.ts +1 -2
  54. package/dist/commonjs/Clients.d.ts.map +1 -1
  55. package/dist/commonjs/Clients.js +25 -26
  56. package/dist/commonjs/Clients.js.map +1 -1
  57. package/dist/commonjs/ContainerClient.d.ts +1 -2
  58. package/dist/commonjs/ContainerClient.d.ts.map +1 -1
  59. package/dist/commonjs/ContainerClient.js +8 -9
  60. package/dist/commonjs/ContainerClient.js.map +1 -1
  61. package/dist/commonjs/Pipeline.d.ts +2 -3
  62. package/dist/commonjs/Pipeline.d.ts.map +1 -1
  63. package/dist/commonjs/Pipeline.js +12 -20
  64. package/dist/commonjs/Pipeline.js.map +1 -1
  65. package/dist/commonjs/StorageClient.d.ts +1 -2
  66. package/dist/commonjs/StorageClient.d.ts.map +1 -1
  67. package/dist/commonjs/StorageClient.js.map +1 -1
  68. package/dist/commonjs/index.d.ts +1 -10
  69. package/dist/commonjs/index.d.ts.map +1 -1
  70. package/dist/commonjs/index.js +14 -12
  71. package/dist/commonjs/index.js.map +1 -1
  72. package/dist/commonjs/sas/AccountSASSignatureValues.d.ts +1 -1
  73. package/dist/commonjs/sas/AccountSASSignatureValues.d.ts.map +1 -1
  74. package/dist/commonjs/sas/AccountSASSignatureValues.js.map +1 -1
  75. package/dist/commonjs/sas/BlobSASSignatureValues.d.ts +1 -1
  76. package/dist/commonjs/sas/BlobSASSignatureValues.d.ts.map +1 -1
  77. package/dist/commonjs/sas/BlobSASSignatureValues.js +2 -2
  78. package/dist/commonjs/sas/BlobSASSignatureValues.js.map +1 -1
  79. package/dist/commonjs/tsdoc-metadata.json +1 -1
  80. package/dist/commonjs/utils/constants.js +1 -1
  81. package/dist/commonjs/utils/constants.js.map +1 -1
  82. package/dist/esm/BlobBatch.d.ts +1 -2
  83. package/dist/esm/BlobBatch.d.ts.map +1 -1
  84. package/dist/esm/BlobBatch.js +1 -3
  85. package/dist/esm/BlobBatch.js.map +1 -1
  86. package/dist/esm/BlobBatchClient.d.ts +1 -2
  87. package/dist/esm/BlobBatchClient.d.ts.map +1 -1
  88. package/dist/esm/BlobBatchClient.js +1 -1
  89. package/dist/esm/BlobBatchClient.js.map +1 -1
  90. package/dist/esm/BlobServiceClient.d.ts +1 -2
  91. package/dist/esm/BlobServiceClient.d.ts.map +1 -1
  92. package/dist/esm/BlobServiceClient.js +1 -2
  93. package/dist/esm/BlobServiceClient.js.map +1 -1
  94. package/dist/esm/Clients.d.ts +1 -2
  95. package/dist/esm/Clients.d.ts.map +1 -1
  96. package/dist/esm/Clients.js +1 -2
  97. package/dist/esm/Clients.js.map +1 -1
  98. package/dist/esm/ContainerClient.d.ts +1 -2
  99. package/dist/esm/ContainerClient.d.ts.map +1 -1
  100. package/dist/esm/ContainerClient.js +1 -2
  101. package/dist/esm/ContainerClient.js.map +1 -1
  102. package/dist/esm/Pipeline.d.ts +2 -3
  103. package/dist/esm/Pipeline.d.ts.map +1 -1
  104. package/dist/esm/Pipeline.js +1 -9
  105. package/dist/esm/Pipeline.js.map +1 -1
  106. package/dist/esm/StorageClient.d.ts +1 -2
  107. package/dist/esm/StorageClient.d.ts.map +1 -1
  108. package/dist/esm/StorageClient.js.map +1 -1
  109. package/dist/esm/index.d.ts +1 -10
  110. package/dist/esm/index.d.ts.map +1 -1
  111. package/dist/esm/index.js +1 -10
  112. package/dist/esm/index.js.map +1 -1
  113. package/dist/esm/sas/AccountSASSignatureValues.d.ts +1 -1
  114. package/dist/esm/sas/AccountSASSignatureValues.d.ts.map +1 -1
  115. package/dist/esm/sas/AccountSASSignatureValues.js.map +1 -1
  116. package/dist/esm/sas/BlobSASSignatureValues.d.ts +1 -1
  117. package/dist/esm/sas/BlobSASSignatureValues.d.ts.map +1 -1
  118. package/dist/esm/sas/BlobSASSignatureValues.js +1 -1
  119. package/dist/esm/sas/BlobSASSignatureValues.js.map +1 -1
  120. package/dist/esm/utils/constants.js +1 -1
  121. package/dist/esm/utils/constants.js.map +1 -1
  122. package/dist/react-native/BlobBatch.d.ts +1 -2
  123. package/dist/react-native/BlobBatch.d.ts.map +1 -1
  124. package/dist/react-native/BlobBatch.js +1 -3
  125. package/dist/react-native/BlobBatch.js.map +1 -1
  126. package/dist/react-native/BlobBatchClient.d.ts +1 -2
  127. package/dist/react-native/BlobBatchClient.d.ts.map +1 -1
  128. package/dist/react-native/BlobBatchClient.js +1 -1
  129. package/dist/react-native/BlobBatchClient.js.map +1 -1
  130. package/dist/react-native/BlobServiceClient.d.ts +1 -2
  131. package/dist/react-native/BlobServiceClient.d.ts.map +1 -1
  132. package/dist/react-native/BlobServiceClient.js +1 -2
  133. package/dist/react-native/BlobServiceClient.js.map +1 -1
  134. package/dist/react-native/Clients.d.ts +1 -2
  135. package/dist/react-native/Clients.d.ts.map +1 -1
  136. package/dist/react-native/Clients.js +1 -2
  137. package/dist/react-native/Clients.js.map +1 -1
  138. package/dist/react-native/ContainerClient.d.ts +1 -2
  139. package/dist/react-native/ContainerClient.d.ts.map +1 -1
  140. package/dist/react-native/ContainerClient.js +1 -2
  141. package/dist/react-native/ContainerClient.js.map +1 -1
  142. package/dist/react-native/Pipeline.d.ts +2 -3
  143. package/dist/react-native/Pipeline.d.ts.map +1 -1
  144. package/dist/react-native/Pipeline.js +1 -9
  145. package/dist/react-native/Pipeline.js.map +1 -1
  146. package/dist/react-native/StorageClient.d.ts +1 -2
  147. package/dist/react-native/StorageClient.d.ts.map +1 -1
  148. package/dist/react-native/StorageClient.js.map +1 -1
  149. package/dist/react-native/index.d.ts +1 -10
  150. package/dist/react-native/index.d.ts.map +1 -1
  151. package/dist/react-native/index.js +1 -10
  152. package/dist/react-native/index.js.map +1 -1
  153. package/dist/react-native/sas/AccountSASSignatureValues.d.ts +1 -1
  154. package/dist/react-native/sas/AccountSASSignatureValues.d.ts.map +1 -1
  155. package/dist/react-native/sas/AccountSASSignatureValues.js.map +1 -1
  156. package/dist/react-native/sas/BlobSASSignatureValues.d.ts +1 -1
  157. package/dist/react-native/sas/BlobSASSignatureValues.d.ts.map +1 -1
  158. package/dist/react-native/sas/BlobSASSignatureValues.js +1 -1
  159. package/dist/react-native/sas/BlobSASSignatureValues.js.map +1 -1
  160. package/dist/react-native/utils/constants.js +1 -1
  161. package/dist/react-native/utils/constants.js.map +1 -1
  162. package/package.json +18 -18
  163. package/dist/browser/StorageBrowserPolicyFactory.d.ts +0 -16
  164. package/dist/browser/StorageBrowserPolicyFactory.d.ts.map +0 -1
  165. package/dist/browser/StorageBrowserPolicyFactory.js +0 -19
  166. package/dist/browser/StorageBrowserPolicyFactory.js.map +0 -1
  167. package/dist/browser/StorageRetryPolicyFactory.d.ts +0 -66
  168. package/dist/browser/StorageRetryPolicyFactory.d.ts.map +0 -1
  169. package/dist/browser/StorageRetryPolicyFactory.js +0 -28
  170. package/dist/browser/StorageRetryPolicyFactory.js.map +0 -1
  171. package/dist/browser/credentials/AnonymousCredential.d.ts +0 -19
  172. package/dist/browser/credentials/AnonymousCredential.d.ts.map +0 -1
  173. package/dist/browser/credentials/AnonymousCredential.js +0 -22
  174. package/dist/browser/credentials/AnonymousCredential.js.map +0 -1
  175. package/dist/browser/credentials/Credential.d.ts +0 -20
  176. package/dist/browser/credentials/Credential.d.ts.map +0 -1
  177. package/dist/browser/credentials/Credential.js +0 -18
  178. package/dist/browser/credentials/Credential.js.map +0 -1
  179. package/dist/browser/credentials/StorageSharedKeyCredential-browser.d.mts.map +0 -1
  180. package/dist/browser/credentials/StorageSharedKeyCredential-browser.mjs.map +0 -1
  181. package/dist/browser/credentials/StorageSharedKeyCredential.d.ts +0 -3
  182. package/dist/browser/credentials/StorageSharedKeyCredential.js +0 -5
  183. package/dist/browser/policies/AnonymousCredentialPolicy.d.ts +0 -15
  184. package/dist/browser/policies/AnonymousCredentialPolicy.d.ts.map +0 -1
  185. package/dist/browser/policies/AnonymousCredentialPolicy.js +0 -20
  186. package/dist/browser/policies/AnonymousCredentialPolicy.js.map +0 -1
  187. package/dist/browser/policies/CredentialPolicy.d.ts +0 -22
  188. package/dist/browser/policies/CredentialPolicy.d.ts.map +0 -1
  189. package/dist/browser/policies/CredentialPolicy.js +0 -29
  190. package/dist/browser/policies/CredentialPolicy.js.map +0 -1
  191. package/dist/browser/policies/RequestPolicy.d.ts +0 -45
  192. package/dist/browser/policies/RequestPolicy.d.ts.map +0 -1
  193. package/dist/browser/policies/RequestPolicy.js +0 -42
  194. package/dist/browser/policies/RequestPolicy.js.map +0 -1
  195. package/dist/browser/policies/StorageBrowserPolicy.d.ts +0 -28
  196. package/dist/browser/policies/StorageBrowserPolicy.d.ts.map +0 -1
  197. package/dist/browser/policies/StorageBrowserPolicy.js +0 -47
  198. package/dist/browser/policies/StorageBrowserPolicy.js.map +0 -1
  199. package/dist/browser/policies/StorageBrowserPolicyV2.d.ts +0 -11
  200. package/dist/browser/policies/StorageBrowserPolicyV2.d.ts.map +0 -1
  201. package/dist/browser/policies/StorageBrowserPolicyV2.js +0 -31
  202. package/dist/browser/policies/StorageBrowserPolicyV2.js.map +0 -1
  203. package/dist/browser/policies/StorageCorrectContentLengthPolicy-browser.d.mts.map +0 -1
  204. package/dist/browser/policies/StorageCorrectContentLengthPolicy-browser.mjs.map +0 -1
  205. package/dist/browser/policies/StorageCorrectContentLengthPolicy.d.ts +0 -10
  206. package/dist/browser/policies/StorageCorrectContentLengthPolicy.js +0 -18
  207. package/dist/browser/policies/StorageRetryPolicy.d.ts +0 -62
  208. package/dist/browser/policies/StorageRetryPolicy.d.ts.map +0 -1
  209. package/dist/browser/policies/StorageRetryPolicy.js +0 -219
  210. package/dist/browser/policies/StorageRetryPolicy.js.map +0 -1
  211. package/dist/browser/policies/StorageRetryPolicyType.d.ts +0 -14
  212. package/dist/browser/policies/StorageRetryPolicyType.d.ts.map +0 -1
  213. package/dist/browser/policies/StorageRetryPolicyType.js +0 -17
  214. package/dist/browser/policies/StorageRetryPolicyType.js.map +0 -1
  215. package/dist/browser/policies/StorageRetryPolicyV2.d.ts +0 -11
  216. package/dist/browser/policies/StorageRetryPolicyV2.d.ts.map +0 -1
  217. package/dist/browser/policies/StorageRetryPolicyV2.js +0 -164
  218. package/dist/browser/policies/StorageRetryPolicyV2.js.map +0 -1
  219. package/dist/browser/policies/StorageSharedKeyCredentialPolicy.d.ts +0 -54
  220. package/dist/browser/policies/StorageSharedKeyCredentialPolicy.d.ts.map +0 -1
  221. package/dist/browser/policies/StorageSharedKeyCredentialPolicy.js +0 -145
  222. package/dist/browser/policies/StorageSharedKeyCredentialPolicy.js.map +0 -1
  223. package/dist/browser/policies/StorageSharedKeyCredentialPolicyV2-browser.d.mts.map +0 -1
  224. package/dist/browser/policies/StorageSharedKeyCredentialPolicyV2-browser.mjs.map +0 -1
  225. package/dist/browser/policies/StorageSharedKeyCredentialPolicyV2.d.ts +0 -17
  226. package/dist/browser/policies/StorageSharedKeyCredentialPolicyV2.js +0 -18
  227. package/dist/commonjs/StorageBrowserPolicyFactory.d.ts +0 -16
  228. package/dist/commonjs/StorageBrowserPolicyFactory.d.ts.map +0 -1
  229. package/dist/commonjs/StorageBrowserPolicyFactory.js +0 -23
  230. package/dist/commonjs/StorageBrowserPolicyFactory.js.map +0 -1
  231. package/dist/commonjs/StorageRetryPolicyFactory.d.ts +0 -66
  232. package/dist/commonjs/StorageRetryPolicyFactory.d.ts.map +0 -1
  233. package/dist/commonjs/StorageRetryPolicyFactory.js +0 -33
  234. package/dist/commonjs/StorageRetryPolicyFactory.js.map +0 -1
  235. package/dist/commonjs/credentials/AnonymousCredential.d.ts +0 -19
  236. package/dist/commonjs/credentials/AnonymousCredential.d.ts.map +0 -1
  237. package/dist/commonjs/credentials/AnonymousCredential.js +0 -26
  238. package/dist/commonjs/credentials/AnonymousCredential.js.map +0 -1
  239. package/dist/commonjs/credentials/Credential.d.ts +0 -20
  240. package/dist/commonjs/credentials/Credential.d.ts.map +0 -1
  241. package/dist/commonjs/credentials/Credential.js +0 -22
  242. package/dist/commonjs/credentials/Credential.js.map +0 -1
  243. package/dist/commonjs/credentials/StorageSharedKeyCredential.d.ts +0 -38
  244. package/dist/commonjs/credentials/StorageSharedKeyCredential.d.ts.map +0 -1
  245. package/dist/commonjs/credentials/StorageSharedKeyCredential.js +0 -52
  246. package/dist/commonjs/credentials/StorageSharedKeyCredential.js.map +0 -1
  247. package/dist/commonjs/policies/AnonymousCredentialPolicy.d.ts +0 -15
  248. package/dist/commonjs/policies/AnonymousCredentialPolicy.d.ts.map +0 -1
  249. package/dist/commonjs/policies/AnonymousCredentialPolicy.js +0 -24
  250. package/dist/commonjs/policies/AnonymousCredentialPolicy.js.map +0 -1
  251. package/dist/commonjs/policies/CredentialPolicy.d.ts +0 -22
  252. package/dist/commonjs/policies/CredentialPolicy.d.ts.map +0 -1
  253. package/dist/commonjs/policies/CredentialPolicy.js +0 -33
  254. package/dist/commonjs/policies/CredentialPolicy.js.map +0 -1
  255. package/dist/commonjs/policies/RequestPolicy.d.ts +0 -45
  256. package/dist/commonjs/policies/RequestPolicy.d.ts.map +0 -1
  257. package/dist/commonjs/policies/RequestPolicy.js +0 -46
  258. package/dist/commonjs/policies/RequestPolicy.js.map +0 -1
  259. package/dist/commonjs/policies/StorageBrowserPolicy.d.ts +0 -28
  260. package/dist/commonjs/policies/StorageBrowserPolicy.d.ts.map +0 -1
  261. package/dist/commonjs/policies/StorageBrowserPolicy.js +0 -51
  262. package/dist/commonjs/policies/StorageBrowserPolicy.js.map +0 -1
  263. package/dist/commonjs/policies/StorageBrowserPolicyV2.d.ts +0 -11
  264. package/dist/commonjs/policies/StorageBrowserPolicyV2.d.ts.map +0 -1
  265. package/dist/commonjs/policies/StorageBrowserPolicyV2.js +0 -35
  266. package/dist/commonjs/policies/StorageBrowserPolicyV2.js.map +0 -1
  267. package/dist/commonjs/policies/StorageCorrectContentLengthPolicy.d.ts +0 -10
  268. package/dist/commonjs/policies/StorageCorrectContentLengthPolicy.d.ts.map +0 -1
  269. package/dist/commonjs/policies/StorageCorrectContentLengthPolicy.js +0 -31
  270. package/dist/commonjs/policies/StorageCorrectContentLengthPolicy.js.map +0 -1
  271. package/dist/commonjs/policies/StorageRetryPolicy.d.ts +0 -62
  272. package/dist/commonjs/policies/StorageRetryPolicy.d.ts.map +0 -1
  273. package/dist/commonjs/policies/StorageRetryPolicy.js +0 -224
  274. package/dist/commonjs/policies/StorageRetryPolicy.js.map +0 -1
  275. package/dist/commonjs/policies/StorageRetryPolicyType.d.ts +0 -14
  276. package/dist/commonjs/policies/StorageRetryPolicyType.d.ts.map +0 -1
  277. package/dist/commonjs/policies/StorageRetryPolicyType.js +0 -20
  278. package/dist/commonjs/policies/StorageRetryPolicyType.js.map +0 -1
  279. package/dist/commonjs/policies/StorageRetryPolicyV2.d.ts +0 -11
  280. package/dist/commonjs/policies/StorageRetryPolicyV2.d.ts.map +0 -1
  281. package/dist/commonjs/policies/StorageRetryPolicyV2.js +0 -168
  282. package/dist/commonjs/policies/StorageRetryPolicyV2.js.map +0 -1
  283. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicy.d.ts +0 -54
  284. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicy.d.ts.map +0 -1
  285. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicy.js +0 -149
  286. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicy.js.map +0 -1
  287. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicyV2.d.ts +0 -17
  288. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicyV2.d.ts.map +0 -1
  289. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicyV2.js +0 -136
  290. package/dist/commonjs/policies/StorageSharedKeyCredentialPolicyV2.js.map +0 -1
  291. package/dist/esm/StorageBrowserPolicyFactory.d.ts +0 -16
  292. package/dist/esm/StorageBrowserPolicyFactory.d.ts.map +0 -1
  293. package/dist/esm/StorageBrowserPolicyFactory.js +0 -19
  294. package/dist/esm/StorageBrowserPolicyFactory.js.map +0 -1
  295. package/dist/esm/StorageRetryPolicyFactory.d.ts +0 -66
  296. package/dist/esm/StorageRetryPolicyFactory.d.ts.map +0 -1
  297. package/dist/esm/StorageRetryPolicyFactory.js +0 -28
  298. package/dist/esm/StorageRetryPolicyFactory.js.map +0 -1
  299. package/dist/esm/credentials/AnonymousCredential.d.ts +0 -19
  300. package/dist/esm/credentials/AnonymousCredential.d.ts.map +0 -1
  301. package/dist/esm/credentials/AnonymousCredential.js +0 -22
  302. package/dist/esm/credentials/AnonymousCredential.js.map +0 -1
  303. package/dist/esm/credentials/Credential.d.ts +0 -20
  304. package/dist/esm/credentials/Credential.d.ts.map +0 -1
  305. package/dist/esm/credentials/Credential.js +0 -18
  306. package/dist/esm/credentials/Credential.js.map +0 -1
  307. package/dist/esm/credentials/StorageSharedKeyCredential.d.ts +0 -38
  308. package/dist/esm/credentials/StorageSharedKeyCredential.d.ts.map +0 -1
  309. package/dist/esm/credentials/StorageSharedKeyCredential.js +0 -48
  310. package/dist/esm/credentials/StorageSharedKeyCredential.js.map +0 -1
  311. package/dist/esm/policies/AnonymousCredentialPolicy.d.ts +0 -15
  312. package/dist/esm/policies/AnonymousCredentialPolicy.d.ts.map +0 -1
  313. package/dist/esm/policies/AnonymousCredentialPolicy.js +0 -20
  314. package/dist/esm/policies/AnonymousCredentialPolicy.js.map +0 -1
  315. package/dist/esm/policies/CredentialPolicy.d.ts +0 -22
  316. package/dist/esm/policies/CredentialPolicy.d.ts.map +0 -1
  317. package/dist/esm/policies/CredentialPolicy.js +0 -29
  318. package/dist/esm/policies/CredentialPolicy.js.map +0 -1
  319. package/dist/esm/policies/RequestPolicy.d.ts +0 -45
  320. package/dist/esm/policies/RequestPolicy.d.ts.map +0 -1
  321. package/dist/esm/policies/RequestPolicy.js +0 -42
  322. package/dist/esm/policies/RequestPolicy.js.map +0 -1
  323. package/dist/esm/policies/StorageBrowserPolicy.d.ts +0 -28
  324. package/dist/esm/policies/StorageBrowserPolicy.d.ts.map +0 -1
  325. package/dist/esm/policies/StorageBrowserPolicy.js +0 -47
  326. package/dist/esm/policies/StorageBrowserPolicy.js.map +0 -1
  327. package/dist/esm/policies/StorageBrowserPolicyV2.d.ts +0 -11
  328. package/dist/esm/policies/StorageBrowserPolicyV2.d.ts.map +0 -1
  329. package/dist/esm/policies/StorageBrowserPolicyV2.js +0 -31
  330. package/dist/esm/policies/StorageBrowserPolicyV2.js.map +0 -1
  331. package/dist/esm/policies/StorageCorrectContentLengthPolicy.d.ts +0 -10
  332. package/dist/esm/policies/StorageCorrectContentLengthPolicy.d.ts.map +0 -1
  333. package/dist/esm/policies/StorageCorrectContentLengthPolicy.js +0 -27
  334. package/dist/esm/policies/StorageCorrectContentLengthPolicy.js.map +0 -1
  335. package/dist/esm/policies/StorageRetryPolicy.d.ts +0 -62
  336. package/dist/esm/policies/StorageRetryPolicy.d.ts.map +0 -1
  337. package/dist/esm/policies/StorageRetryPolicy.js +0 -219
  338. package/dist/esm/policies/StorageRetryPolicy.js.map +0 -1
  339. package/dist/esm/policies/StorageRetryPolicyType.d.ts +0 -14
  340. package/dist/esm/policies/StorageRetryPolicyType.d.ts.map +0 -1
  341. package/dist/esm/policies/StorageRetryPolicyType.js +0 -17
  342. package/dist/esm/policies/StorageRetryPolicyType.js.map +0 -1
  343. package/dist/esm/policies/StorageRetryPolicyV2.d.ts +0 -11
  344. package/dist/esm/policies/StorageRetryPolicyV2.d.ts.map +0 -1
  345. package/dist/esm/policies/StorageRetryPolicyV2.js +0 -164
  346. package/dist/esm/policies/StorageRetryPolicyV2.js.map +0 -1
  347. package/dist/esm/policies/StorageSharedKeyCredentialPolicy.d.ts +0 -54
  348. package/dist/esm/policies/StorageSharedKeyCredentialPolicy.d.ts.map +0 -1
  349. package/dist/esm/policies/StorageSharedKeyCredentialPolicy.js +0 -145
  350. package/dist/esm/policies/StorageSharedKeyCredentialPolicy.js.map +0 -1
  351. package/dist/esm/policies/StorageSharedKeyCredentialPolicyV2.d.ts +0 -17
  352. package/dist/esm/policies/StorageSharedKeyCredentialPolicyV2.d.ts.map +0 -1
  353. package/dist/esm/policies/StorageSharedKeyCredentialPolicyV2.js +0 -132
  354. package/dist/esm/policies/StorageSharedKeyCredentialPolicyV2.js.map +0 -1
  355. package/dist/react-native/StorageBrowserPolicyFactory.d.ts +0 -16
  356. package/dist/react-native/StorageBrowserPolicyFactory.d.ts.map +0 -1
  357. package/dist/react-native/StorageBrowserPolicyFactory.js +0 -19
  358. package/dist/react-native/StorageBrowserPolicyFactory.js.map +0 -1
  359. package/dist/react-native/StorageRetryPolicyFactory.d.ts +0 -66
  360. package/dist/react-native/StorageRetryPolicyFactory.d.ts.map +0 -1
  361. package/dist/react-native/StorageRetryPolicyFactory.js +0 -28
  362. package/dist/react-native/StorageRetryPolicyFactory.js.map +0 -1
  363. package/dist/react-native/credentials/AnonymousCredential.d.ts +0 -19
  364. package/dist/react-native/credentials/AnonymousCredential.d.ts.map +0 -1
  365. package/dist/react-native/credentials/AnonymousCredential.js +0 -22
  366. package/dist/react-native/credentials/AnonymousCredential.js.map +0 -1
  367. package/dist/react-native/credentials/Credential.d.ts +0 -20
  368. package/dist/react-native/credentials/Credential.d.ts.map +0 -1
  369. package/dist/react-native/credentials/Credential.js +0 -18
  370. package/dist/react-native/credentials/Credential.js.map +0 -1
  371. package/dist/react-native/credentials/StorageSharedKeyCredential.d.ts +0 -38
  372. package/dist/react-native/credentials/StorageSharedKeyCredential.d.ts.map +0 -1
  373. package/dist/react-native/credentials/StorageSharedKeyCredential.js +0 -48
  374. package/dist/react-native/credentials/StorageSharedKeyCredential.js.map +0 -1
  375. package/dist/react-native/policies/AnonymousCredentialPolicy.d.ts +0 -15
  376. package/dist/react-native/policies/AnonymousCredentialPolicy.d.ts.map +0 -1
  377. package/dist/react-native/policies/AnonymousCredentialPolicy.js +0 -20
  378. package/dist/react-native/policies/AnonymousCredentialPolicy.js.map +0 -1
  379. package/dist/react-native/policies/CredentialPolicy.d.ts +0 -22
  380. package/dist/react-native/policies/CredentialPolicy.d.ts.map +0 -1
  381. package/dist/react-native/policies/CredentialPolicy.js +0 -29
  382. package/dist/react-native/policies/CredentialPolicy.js.map +0 -1
  383. package/dist/react-native/policies/RequestPolicy.d.ts +0 -45
  384. package/dist/react-native/policies/RequestPolicy.d.ts.map +0 -1
  385. package/dist/react-native/policies/RequestPolicy.js +0 -42
  386. package/dist/react-native/policies/RequestPolicy.js.map +0 -1
  387. package/dist/react-native/policies/StorageBrowserPolicy.d.ts +0 -28
  388. package/dist/react-native/policies/StorageBrowserPolicy.d.ts.map +0 -1
  389. package/dist/react-native/policies/StorageBrowserPolicy.js +0 -47
  390. package/dist/react-native/policies/StorageBrowserPolicy.js.map +0 -1
  391. package/dist/react-native/policies/StorageBrowserPolicyV2.d.ts +0 -11
  392. package/dist/react-native/policies/StorageBrowserPolicyV2.d.ts.map +0 -1
  393. package/dist/react-native/policies/StorageBrowserPolicyV2.js +0 -31
  394. package/dist/react-native/policies/StorageBrowserPolicyV2.js.map +0 -1
  395. package/dist/react-native/policies/StorageCorrectContentLengthPolicy.d.ts +0 -10
  396. package/dist/react-native/policies/StorageCorrectContentLengthPolicy.d.ts.map +0 -1
  397. package/dist/react-native/policies/StorageCorrectContentLengthPolicy.js +0 -27
  398. package/dist/react-native/policies/StorageCorrectContentLengthPolicy.js.map +0 -1
  399. package/dist/react-native/policies/StorageRetryPolicy.d.ts +0 -62
  400. package/dist/react-native/policies/StorageRetryPolicy.d.ts.map +0 -1
  401. package/dist/react-native/policies/StorageRetryPolicy.js +0 -219
  402. package/dist/react-native/policies/StorageRetryPolicy.js.map +0 -1
  403. package/dist/react-native/policies/StorageRetryPolicyType.d.ts +0 -14
  404. package/dist/react-native/policies/StorageRetryPolicyType.d.ts.map +0 -1
  405. package/dist/react-native/policies/StorageRetryPolicyType.js +0 -17
  406. package/dist/react-native/policies/StorageRetryPolicyType.js.map +0 -1
  407. package/dist/react-native/policies/StorageRetryPolicyV2.d.ts +0 -11
  408. package/dist/react-native/policies/StorageRetryPolicyV2.d.ts.map +0 -1
  409. package/dist/react-native/policies/StorageRetryPolicyV2.js +0 -164
  410. package/dist/react-native/policies/StorageRetryPolicyV2.js.map +0 -1
  411. package/dist/react-native/policies/StorageSharedKeyCredentialPolicy.d.ts +0 -54
  412. package/dist/react-native/policies/StorageSharedKeyCredentialPolicy.d.ts.map +0 -1
  413. package/dist/react-native/policies/StorageSharedKeyCredentialPolicy.js +0 -145
  414. package/dist/react-native/policies/StorageSharedKeyCredentialPolicy.js.map +0 -1
  415. package/dist/react-native/policies/StorageSharedKeyCredentialPolicyV2.d.ts +0 -17
  416. package/dist/react-native/policies/StorageSharedKeyCredentialPolicyV2.d.ts.map +0 -1
  417. package/dist/react-native/policies/StorageSharedKeyCredentialPolicyV2.js +0 -132
  418. package/dist/react-native/policies/StorageSharedKeyCredentialPolicyV2.js.map +0 -1
@@ -1,62 +0,0 @@
1
- import type { RequestPolicy, RequestPolicyOptionsLike as RequestPolicyOptions, RequestPolicyFactory, WebResourceLike as WebResource, CompatResponse as HttpOperationResponse } from "@azure/core-http-compat";
2
- import { BaseRequestPolicy } from "./RequestPolicy.js";
3
- import type { RestError } from "@azure/core-rest-pipeline";
4
- import { type StorageRetryOptions } from "../StorageRetryPolicyFactory.js";
5
- /**
6
- * A factory method used to generated a RetryPolicy factory.
7
- *
8
- * @param retryOptions -
9
- */
10
- export declare function NewRetryPolicyFactory(retryOptions?: StorageRetryOptions): RequestPolicyFactory;
11
- /**
12
- * Retry policy with exponential retry and linear retry implemented.
13
- */
14
- export declare class StorageRetryPolicy extends BaseRequestPolicy {
15
- /**
16
- * RetryOptions.
17
- */
18
- private readonly retryOptions;
19
- /**
20
- * Creates an instance of RetryPolicy.
21
- *
22
- * @param nextPolicy -
23
- * @param options -
24
- * @param retryOptions -
25
- */
26
- constructor(nextPolicy: RequestPolicy, options: RequestPolicyOptions, retryOptions?: StorageRetryOptions);
27
- /**
28
- * Sends request.
29
- *
30
- * @param request -
31
- */
32
- sendRequest(request: WebResource): Promise<HttpOperationResponse>;
33
- /**
34
- * Decide and perform next retry. Won't mutate request parameter.
35
- *
36
- * @param request -
37
- * @param secondaryHas404 - If attempt was against the secondary & it returned a StatusNotFound (404), then
38
- * the resource was not found. This may be due to replication delay. So, in this
39
- * case, we'll never try the secondary again for this operation.
40
- * @param attempt - How many retries has been attempted to performed, starting from 1, which includes
41
- * the attempt will be performed by this method call.
42
- */
43
- protected attemptSendRequest(request: WebResource, secondaryHas404: boolean, attempt: number): Promise<HttpOperationResponse>;
44
- /**
45
- * Decide whether to retry according to last HTTP response and retry counters.
46
- *
47
- * @param isPrimaryRetry -
48
- * @param attempt -
49
- * @param response -
50
- * @param err -
51
- */
52
- protected shouldRetry(isPrimaryRetry: boolean, attempt: number, response?: HttpOperationResponse, err?: RestError): boolean;
53
- /**
54
- * Delay a calculated time between retries.
55
- *
56
- * @param isPrimaryRetry -
57
- * @param attempt -
58
- * @param abortSignal -
59
- */
60
- private delay;
61
- }
62
- //# sourceMappingURL=StorageRetryPolicy.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageRetryPolicy.d.ts","sourceRoot":"","sources":["../../../src/policies/StorageRetryPolicy.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,aAAa,EACb,wBAAwB,IAAI,oBAAoB,EAChD,oBAAoB,EACpB,eAAe,IAAI,WAAW,EAC9B,cAAc,IAAI,qBAAqB,EACxC,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AAM3E;;;;GAIG;AACH,wBAAgB,qBAAqB,CAAC,YAAY,CAAC,EAAE,mBAAmB,GAAG,oBAAoB,CAM9F;AAcD;;GAEG;AACH,qBAAa,kBAAmB,SAAQ,iBAAiB;IACvD;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAsB;IAEnD;;;;;;OAMG;gBAED,UAAU,EAAE,aAAa,EACzB,OAAO,EAAE,oBAAoB,EAC7B,YAAY,GAAE,mBAA2C;IAyC3D;;;;OAIG;IACU,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAI9E;;;;;;;;;OASG;cACa,kBAAkB,CAChC,OAAO,EAAE,WAAW,EACpB,eAAe,EAAE,OAAO,EACxB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,qBAAqB,CAAC;IA0CjC;;;;;;;OAOG;IACH,SAAS,CAAC,WAAW,CACnB,cAAc,EAAE,OAAO,EACvB,OAAO,EAAE,MAAM,EACf,QAAQ,CAAC,EAAE,qBAAqB,EAChC,GAAG,CAAC,EAAE,SAAS,GACd,OAAO;IA6EV;;;;;;OAMG;YACW,KAAK;CA0BpB"}
@@ -1,219 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import { AbortError } from "@azure/abort-controller";
4
- import { BaseRequestPolicy } from "./RequestPolicy.js";
5
- import { HeaderConstants, URLConstants } from "../utils/constants.js";
6
- import { delay, setURLHost, setURLParameter } from "../utils/utils.common.js";
7
- import { logger } from "../log.js";
8
- import { StorageRetryPolicyType } from "./StorageRetryPolicyType.js";
9
- /**
10
- * A factory method used to generated a RetryPolicy factory.
11
- *
12
- * @param retryOptions -
13
- */
14
- export function NewRetryPolicyFactory(retryOptions) {
15
- return {
16
- create: (nextPolicy, options) => {
17
- return new StorageRetryPolicy(nextPolicy, options, retryOptions);
18
- },
19
- };
20
- }
21
- // Default values of StorageRetryOptions
22
- const DEFAULT_RETRY_OPTIONS = {
23
- maxRetryDelayInMs: 120 * 1000,
24
- maxTries: 4,
25
- retryDelayInMs: 4 * 1000,
26
- retryPolicyType: StorageRetryPolicyType.EXPONENTIAL,
27
- secondaryHost: "",
28
- tryTimeoutInMs: undefined, // Use server side default timeout strategy
29
- };
30
- const RETRY_ABORT_ERROR = new AbortError("The operation was aborted.");
31
- /**
32
- * Retry policy with exponential retry and linear retry implemented.
33
- */
34
- export class StorageRetryPolicy extends BaseRequestPolicy {
35
- /**
36
- * RetryOptions.
37
- */
38
- retryOptions;
39
- /**
40
- * Creates an instance of RetryPolicy.
41
- *
42
- * @param nextPolicy -
43
- * @param options -
44
- * @param retryOptions -
45
- */
46
- constructor(nextPolicy, options, retryOptions = DEFAULT_RETRY_OPTIONS) {
47
- super(nextPolicy, options);
48
- // Initialize retry options
49
- this.retryOptions = {
50
- retryPolicyType: retryOptions.retryPolicyType
51
- ? retryOptions.retryPolicyType
52
- : DEFAULT_RETRY_OPTIONS.retryPolicyType,
53
- maxTries: retryOptions.maxTries && retryOptions.maxTries >= 1
54
- ? Math.floor(retryOptions.maxTries)
55
- : DEFAULT_RETRY_OPTIONS.maxTries,
56
- tryTimeoutInMs: retryOptions.tryTimeoutInMs && retryOptions.tryTimeoutInMs >= 0
57
- ? retryOptions.tryTimeoutInMs
58
- : DEFAULT_RETRY_OPTIONS.tryTimeoutInMs,
59
- retryDelayInMs: retryOptions.retryDelayInMs && retryOptions.retryDelayInMs >= 0
60
- ? Math.min(retryOptions.retryDelayInMs, retryOptions.maxRetryDelayInMs
61
- ? retryOptions.maxRetryDelayInMs
62
- : DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs)
63
- : DEFAULT_RETRY_OPTIONS.retryDelayInMs,
64
- maxRetryDelayInMs: retryOptions.maxRetryDelayInMs && retryOptions.maxRetryDelayInMs >= 0
65
- ? retryOptions.maxRetryDelayInMs
66
- : DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs,
67
- secondaryHost: retryOptions.secondaryHost
68
- ? retryOptions.secondaryHost
69
- : DEFAULT_RETRY_OPTIONS.secondaryHost,
70
- };
71
- }
72
- /**
73
- * Sends request.
74
- *
75
- * @param request -
76
- */
77
- async sendRequest(request) {
78
- return this.attemptSendRequest(request, false, 1);
79
- }
80
- /**
81
- * Decide and perform next retry. Won't mutate request parameter.
82
- *
83
- * @param request -
84
- * @param secondaryHas404 - If attempt was against the secondary & it returned a StatusNotFound (404), then
85
- * the resource was not found. This may be due to replication delay. So, in this
86
- * case, we'll never try the secondary again for this operation.
87
- * @param attempt - How many retries has been attempted to performed, starting from 1, which includes
88
- * the attempt will be performed by this method call.
89
- */
90
- async attemptSendRequest(request, secondaryHas404, attempt) {
91
- const newRequest = request.clone();
92
- const isPrimaryRetry = secondaryHas404 ||
93
- !this.retryOptions.secondaryHost ||
94
- !(request.method === "GET" || request.method === "HEAD" || request.method === "OPTIONS") ||
95
- attempt % 2 === 1;
96
- if (!isPrimaryRetry) {
97
- newRequest.url = setURLHost(newRequest.url, this.retryOptions.secondaryHost);
98
- }
99
- // Set the server-side timeout query parameter "timeout=[seconds]"
100
- if (this.retryOptions.tryTimeoutInMs) {
101
- newRequest.url = setURLParameter(newRequest.url, URLConstants.Parameters.TIMEOUT, Math.floor(this.retryOptions.tryTimeoutInMs / 1000).toString());
102
- }
103
- let response;
104
- try {
105
- logger.info(`RetryPolicy: =====> Try=${attempt} ${isPrimaryRetry ? "Primary" : "Secondary"}`);
106
- response = await this._nextPolicy.sendRequest(newRequest);
107
- if (!this.shouldRetry(isPrimaryRetry, attempt, response)) {
108
- return response;
109
- }
110
- secondaryHas404 = secondaryHas404 || (!isPrimaryRetry && response.status === 404);
111
- }
112
- catch (err) {
113
- logger.error(`RetryPolicy: Caught error, message: ${err.message}, code: ${err.code}`);
114
- if (!this.shouldRetry(isPrimaryRetry, attempt, response, err)) {
115
- throw err;
116
- }
117
- }
118
- await this.delay(isPrimaryRetry, attempt, request.abortSignal);
119
- return this.attemptSendRequest(request, secondaryHas404, ++attempt);
120
- }
121
- /**
122
- * Decide whether to retry according to last HTTP response and retry counters.
123
- *
124
- * @param isPrimaryRetry -
125
- * @param attempt -
126
- * @param response -
127
- * @param err -
128
- */
129
- shouldRetry(isPrimaryRetry, attempt, response, err) {
130
- if (attempt >= this.retryOptions.maxTries) {
131
- logger.info(`RetryPolicy: Attempt(s) ${attempt} >= maxTries ${this.retryOptions
132
- .maxTries}, no further try.`);
133
- return false;
134
- }
135
- // Handle network failures, you may need to customize the list when you implement
136
- // your own http client
137
- const retriableErrors = [
138
- "ETIMEDOUT",
139
- "ESOCKETTIMEDOUT",
140
- "ECONNREFUSED",
141
- "ECONNRESET",
142
- "ENOENT",
143
- "ENOTFOUND",
144
- "TIMEOUT",
145
- "EPIPE",
146
- "REQUEST_SEND_ERROR", // For default xhr based http client provided in ms-rest-js
147
- ];
148
- if (err) {
149
- for (const retriableError of retriableErrors) {
150
- if (err.name.toUpperCase().includes(retriableError) ||
151
- err.message.toUpperCase().includes(retriableError) ||
152
- (err.code && err.code.toString().toUpperCase() === retriableError)) {
153
- logger.info(`RetryPolicy: Network error ${retriableError} found, will retry.`);
154
- return true;
155
- }
156
- }
157
- }
158
- // If attempt was against the secondary & it returned a StatusNotFound (404), then
159
- // the resource was not found. This may be due to replication delay. So, in this
160
- // case, we'll never try the secondary again for this operation.
161
- if (response || err) {
162
- const statusCode = response ? response.status : err ? err.statusCode : 0;
163
- if (!isPrimaryRetry && statusCode === 404) {
164
- logger.info(`RetryPolicy: Secondary access with 404, will retry.`);
165
- return true;
166
- }
167
- // Server internal error or server timeout
168
- if (statusCode === 503 || statusCode === 500) {
169
- logger.info(`RetryPolicy: Will retry for status code ${statusCode}.`);
170
- return true;
171
- }
172
- }
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
- case "InternalError":
180
- case "OperationTimedOut":
181
- case "ServerBusy":
182
- return true;
183
- }
184
- }
185
- }
186
- }
187
- if (err?.code === "PARSE_ERROR" && err?.message.startsWith(`Error "Error: Unclosed root tag`)) {
188
- logger.info("RetryPolicy: Incomplete XML response likely due to service timeout, will retry.");
189
- return true;
190
- }
191
- return false;
192
- }
193
- /**
194
- * Delay a calculated time between retries.
195
- *
196
- * @param isPrimaryRetry -
197
- * @param attempt -
198
- * @param abortSignal -
199
- */
200
- async delay(isPrimaryRetry, attempt, abortSignal) {
201
- let delayTimeInMs = 0;
202
- if (isPrimaryRetry) {
203
- switch (this.retryOptions.retryPolicyType) {
204
- case StorageRetryPolicyType.EXPONENTIAL:
205
- delayTimeInMs = Math.min((Math.pow(2, attempt - 1) - 1) * this.retryOptions.retryDelayInMs, this.retryOptions.maxRetryDelayInMs);
206
- break;
207
- case StorageRetryPolicyType.FIXED:
208
- delayTimeInMs = this.retryOptions.retryDelayInMs;
209
- break;
210
- }
211
- }
212
- else {
213
- delayTimeInMs = Math.random() * 1000;
214
- }
215
- logger.info(`RetryPolicy: Delay for ${delayTimeInMs}ms`);
216
- return delay(delayTimeInMs, abortSignal, RETRY_ABORT_ERROR);
217
- }
218
- }
219
- //# 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\";\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 \"./RequestPolicy.js\";\nimport type { RestError } from \"@azure/core-rest-pipeline\";\nimport { type StorageRetryOptions } from \"../StorageRetryPolicyFactory.js\";\nimport { HeaderConstants, URLConstants } from \"../utils/constants.js\";\nimport { delay, setURLHost, setURLParameter } from \"../utils/utils.common.js\";\nimport { logger } from \"../log.js\";\nimport { StorageRetryPolicyType } from \"./StorageRetryPolicyType.js\";\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// 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 secondaryHost: \"\",\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 secondaryHost: retryOptions.secondaryHost\n ? retryOptions.secondaryHost\n : DEFAULT_RETRY_OPTIONS.secondaryHost,\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 =\n secondaryHas404 ||\n !this.retryOptions.secondaryHost ||\n !(request.method === \"GET\" || request.method === \"HEAD\" || request.method === \"OPTIONS\") ||\n attempt % 2 === 1;\n\n if (!isPrimaryRetry) {\n newRequest.url = setURLHost(newRequest.url, this.retryOptions.secondaryHost!);\n }\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 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 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(\n isPrimaryRetry: boolean,\n attempt: number,\n abortSignal?: AbortSignalLike,\n ): Promise<void> {\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,14 +0,0 @@
1
- /**
2
- * RetryPolicy types.
3
- */
4
- export declare enum StorageRetryPolicyType {
5
- /**
6
- * Exponential retry. Retry time delay grows exponentially.
7
- */
8
- EXPONENTIAL = 0,
9
- /**
10
- * Linear retry. Retry time delay grows linearly.
11
- */
12
- FIXED = 1
13
- }
14
- //# sourceMappingURL=StorageRetryPolicyType.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageRetryPolicyType.d.ts","sourceRoot":"","sources":["../../../src/policies/StorageRetryPolicyType.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,oBAAY,sBAAsB;IAChC;;OAEG;IACH,WAAW,IAAA;IACX;;OAEG;IACH,KAAK,IAAA;CACN"}
@@ -1,17 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- /**
4
- * RetryPolicy types.
5
- */
6
- export var StorageRetryPolicyType;
7
- (function (StorageRetryPolicyType) {
8
- /**
9
- * Exponential retry. Retry time delay grows exponentially.
10
- */
11
- StorageRetryPolicyType[StorageRetryPolicyType["EXPONENTIAL"] = 0] = "EXPONENTIAL";
12
- /**
13
- * Linear retry. Retry time delay grows linearly.
14
- */
15
- StorageRetryPolicyType[StorageRetryPolicyType["FIXED"] = 1] = "FIXED";
16
- })(StorageRetryPolicyType || (StorageRetryPolicyType = {}));
17
- //# sourceMappingURL=StorageRetryPolicyType.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageRetryPolicyType.js","sourceRoot":"","sources":["../../../src/policies/StorageRetryPolicyType.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC;;GAEG;AACH,MAAM,CAAN,IAAY,sBASX;AATD,WAAY,sBAAsB;IAChC;;OAEG;IACH,iFAAW,CAAA;IACX;;OAEG;IACH,qEAAK,CAAA;AACP,CAAC,EATW,sBAAsB,KAAtB,sBAAsB,QASjC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\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"]}
@@ -1,11 +0,0 @@
1
- import type { PipelinePolicy } from "@azure/core-rest-pipeline";
2
- import { type StorageRetryOptions } from "../StorageRetryPolicyFactory.js";
3
- /**
4
- * Name of the {@link storageRetryPolicy}
5
- */
6
- export declare const storageRetryPolicyName = "storageRetryPolicy";
7
- /**
8
- * Retry policy with exponential retry and linear retry implemented.
9
- */
10
- export declare function storageRetryPolicy(options?: StorageRetryOptions): PipelinePolicy;
11
- //# sourceMappingURL=StorageRetryPolicyV2.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageRetryPolicyV2.d.ts","sourceRoot":"","sources":["../../../src/policies/StorageRetryPolicyV2.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,cAAc,EAIf,MAAM,2BAA2B,CAAC;AAGnC,OAAO,EAA0B,KAAK,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AAKnG;;GAEG;AACH,eAAO,MAAM,sBAAsB,uBAAuB,CAAC;AA0B3D;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,GAAE,mBAAwB,GAAG,cAAc,CA+JpF"}
@@ -1,164 +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 { StorageRetryPolicyType } from "../StorageRetryPolicyFactory.js";
7
- import { HeaderConstants, URLConstants } from "../utils/constants.js";
8
- import { delay, setURLHost, setURLParameter } from "../utils/utils.common.js";
9
- import { logger } from "../log.js";
10
- /**
11
- * Name of the {@link storageRetryPolicy}
12
- */
13
- export const storageRetryPolicyName = "storageRetryPolicy";
14
- // Default values of StorageRetryOptions
15
- const DEFAULT_RETRY_OPTIONS = {
16
- maxRetryDelayInMs: 120 * 1000,
17
- maxTries: 4,
18
- retryDelayInMs: 4 * 1000,
19
- retryPolicyType: StorageRetryPolicyType.EXPONENTIAL,
20
- secondaryHost: "",
21
- tryTimeoutInMs: undefined, // Use server side default timeout strategy
22
- };
23
- const retriableErrors = [
24
- "ETIMEDOUT",
25
- "ESOCKETTIMEDOUT",
26
- "ECONNREFUSED",
27
- "ECONNRESET",
28
- "ENOENT",
29
- "ENOTFOUND",
30
- "TIMEOUT",
31
- "EPIPE",
32
- "REQUEST_SEND_ERROR",
33
- ];
34
- const RETRY_ABORT_ERROR = new AbortError("The operation was aborted.");
35
- /**
36
- * Retry policy with exponential retry and linear retry implemented.
37
- */
38
- export function storageRetryPolicy(options = {}) {
39
- const retryPolicyType = options.retryPolicyType ?? DEFAULT_RETRY_OPTIONS.retryPolicyType;
40
- const maxTries = options.maxTries ?? DEFAULT_RETRY_OPTIONS.maxTries;
41
- const retryDelayInMs = options.retryDelayInMs ?? DEFAULT_RETRY_OPTIONS.retryDelayInMs;
42
- const maxRetryDelayInMs = options.maxRetryDelayInMs ?? DEFAULT_RETRY_OPTIONS.maxRetryDelayInMs;
43
- const secondaryHost = options.secondaryHost ?? DEFAULT_RETRY_OPTIONS.secondaryHost;
44
- const tryTimeoutInMs = options.tryTimeoutInMs ?? DEFAULT_RETRY_OPTIONS.tryTimeoutInMs;
45
- function shouldRetry({ isPrimaryRetry, attempt, response, error, }) {
46
- if (attempt >= maxTries) {
47
- logger.info(`RetryPolicy: Attempt(s) ${attempt} >= maxTries ${maxTries}, no further try.`);
48
- return false;
49
- }
50
- if (error) {
51
- for (const retriableError of retriableErrors) {
52
- if (error.name.toUpperCase().includes(retriableError) ||
53
- error.message.toUpperCase().includes(retriableError) ||
54
- (error.code && error.code.toString().toUpperCase() === retriableError)) {
55
- logger.info(`RetryPolicy: Network error ${retriableError} found, will retry.`);
56
- return true;
57
- }
58
- }
59
- if (error?.code === "PARSE_ERROR" &&
60
- error?.message.startsWith(`Error "Error: Unclosed root tag`)) {
61
- logger.info("RetryPolicy: Incomplete XML response likely due to service timeout, will retry.");
62
- return true;
63
- }
64
- }
65
- // If attempt was against the secondary & it returned a StatusNotFound (404), then
66
- // the resource was not found. This may be due to replication delay. So, in this
67
- // case, we'll never try the secondary again for this operation.
68
- if (response || error) {
69
- const statusCode = response?.status ?? error?.statusCode ?? 0;
70
- if (!isPrimaryRetry && statusCode === 404) {
71
- logger.info(`RetryPolicy: Secondary access with 404, will retry.`);
72
- return true;
73
- }
74
- // Server internal error or server timeout
75
- if (statusCode === 503 || statusCode === 500) {
76
- logger.info(`RetryPolicy: Will retry for status code ${statusCode}.`);
77
- return true;
78
- }
79
- }
80
- if (response) {
81
- // Retry select Copy Source Error Codes.
82
- if (response?.status >= 400) {
83
- const copySourceError = response.headers.get(HeaderConstants.X_MS_CopySourceErrorCode);
84
- if (copySourceError !== undefined) {
85
- switch (copySourceError) {
86
- case "InternalError":
87
- case "OperationTimedOut":
88
- case "ServerBusy":
89
- return true;
90
- }
91
- }
92
- }
93
- }
94
- return false;
95
- }
96
- function calculateDelay(isPrimaryRetry, attempt) {
97
- let delayTimeInMs = 0;
98
- if (isPrimaryRetry) {
99
- switch (retryPolicyType) {
100
- case StorageRetryPolicyType.EXPONENTIAL:
101
- delayTimeInMs = Math.min((Math.pow(2, attempt - 1) - 1) * retryDelayInMs, maxRetryDelayInMs);
102
- break;
103
- case StorageRetryPolicyType.FIXED:
104
- delayTimeInMs = retryDelayInMs;
105
- break;
106
- }
107
- }
108
- else {
109
- delayTimeInMs = Math.random() * 1000;
110
- }
111
- logger.info(`RetryPolicy: Delay for ${delayTimeInMs}ms`);
112
- return delayTimeInMs;
113
- }
114
- return {
115
- name: storageRetryPolicyName,
116
- async sendRequest(request, next) {
117
- // Set the server-side timeout query parameter "timeout=[seconds]"
118
- if (tryTimeoutInMs) {
119
- request.url = setURLParameter(request.url, URLConstants.Parameters.TIMEOUT, String(Math.floor(tryTimeoutInMs / 1000)));
120
- }
121
- const primaryUrl = request.url;
122
- const secondaryUrl = secondaryHost ? setURLHost(request.url, secondaryHost) : undefined;
123
- let secondaryHas404 = false;
124
- let attempt = 1;
125
- let retryAgain = true;
126
- let response;
127
- let error;
128
- while (retryAgain) {
129
- const isPrimaryRetry = secondaryHas404 ||
130
- !secondaryUrl ||
131
- !["GET", "HEAD", "OPTIONS"].includes(request.method) ||
132
- attempt % 2 === 1;
133
- request.url = isPrimaryRetry ? primaryUrl : secondaryUrl;
134
- response = undefined;
135
- error = undefined;
136
- try {
137
- logger.info(`RetryPolicy: =====> Try=${attempt} ${isPrimaryRetry ? "Primary" : "Secondary"}`);
138
- response = await next(request);
139
- secondaryHas404 = secondaryHas404 || (!isPrimaryRetry && response.status === 404);
140
- }
141
- catch (e) {
142
- if (isRestError(e)) {
143
- logger.error(`RetryPolicy: Caught error, message: ${e.message}, code: ${e.code}`);
144
- error = e;
145
- }
146
- else {
147
- logger.error(`RetryPolicy: Caught error, message: ${getErrorMessage(e)}`);
148
- throw e;
149
- }
150
- }
151
- retryAgain = shouldRetry({ isPrimaryRetry, attempt, response, error });
152
- if (retryAgain) {
153
- await delay(calculateDelay(isPrimaryRetry, attempt), request.abortSignal, RETRY_ABORT_ERROR);
154
- }
155
- attempt++;
156
- }
157
- if (response) {
158
- return response;
159
- }
160
- throw error ?? new RestError("RetryPolicy failed without known error.");
161
- },
162
- };
163
- }
164
- //# 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 { StorageRetryPolicyType, type StorageRetryOptions } from \"../StorageRetryPolicyFactory.js\";\nimport { HeaderConstants, URLConstants } from \"../utils/constants.js\";\nimport { delay, setURLHost, setURLParameter } from \"../utils/utils.common.js\";\nimport { logger } from \"../log.js\";\n\n/**\n * Name of the {@link storageRetryPolicy}\n */\nexport const storageRetryPolicyName = \"storageRetryPolicy\";\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 secondaryHost = options.secondaryHost ?? DEFAULT_RETRY_OPTIONS.secondaryHost;\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\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 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 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 const secondaryUrl = secondaryHost ? setURLHost(request.url, secondaryHost) : undefined;\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 =\n secondaryHas404 ||\n !secondaryUrl ||\n ![\"GET\", \"HEAD\", \"OPTIONS\"].includes(request.method) ||\n attempt % 2 === 1;\n request.url = isPrimaryRetry ? primaryUrl : secondaryUrl!;\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,54 +0,0 @@
1
- import type { RequestPolicy, RequestPolicyOptionsLike as RequestPolicyOptions, WebResourceLike as WebResource } from "@azure/core-http-compat";
2
- import type { StorageSharedKeyCredential } from "../credentials/StorageSharedKeyCredential.js";
3
- import { CredentialPolicy } from "./CredentialPolicy.js";
4
- /**
5
- * StorageSharedKeyCredentialPolicy is a policy used to sign HTTP request with a shared key.
6
- */
7
- export declare class StorageSharedKeyCredentialPolicy extends CredentialPolicy {
8
- /**
9
- * Reference to StorageSharedKeyCredential which generates StorageSharedKeyCredentialPolicy
10
- */
11
- private readonly factory;
12
- /**
13
- * Creates an instance of StorageSharedKeyCredentialPolicy.
14
- * @param nextPolicy -
15
- * @param options -
16
- * @param factory -
17
- */
18
- constructor(nextPolicy: RequestPolicy, options: RequestPolicyOptions, factory: StorageSharedKeyCredential);
19
- /**
20
- * Signs request.
21
- *
22
- * @param request -
23
- */
24
- protected signRequest(request: WebResource): WebResource;
25
- /**
26
- * Retrieve header value according to shared key sign rules.
27
- * @see https://learn.microsoft.com/rest/api/storageservices/authenticate-with-shared-key
28
- *
29
- * @param request -
30
- * @param headerName -
31
- */
32
- private getHeaderValueToSign;
33
- /**
34
- * To construct the CanonicalizedHeaders portion of the signature string, follow these steps:
35
- * 1. Retrieve all headers for the resource that begin with x-ms-, including the x-ms-date header.
36
- * 2. Convert each HTTP header name to lowercase.
37
- * 3. Sort the headers lexicographically by header name, in ascending order.
38
- * Each header may appear only once in the string.
39
- * 4. Replace any linear whitespace in the header value with a single space.
40
- * 5. Trim any whitespace around the colon in the header.
41
- * 6. Finally, append a new-line character to each canonicalized header in the resulting list.
42
- * Construct the CanonicalizedHeaders string by concatenating all headers in this list into a single string.
43
- *
44
- * @param request -
45
- */
46
- private getCanonicalizedHeadersString;
47
- /**
48
- * Retrieves the webResource canonicalized resource string.
49
- *
50
- * @param request -
51
- */
52
- private getCanonicalizedResourceString;
53
- }
54
- //# sourceMappingURL=StorageSharedKeyCredentialPolicy.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageSharedKeyCredentialPolicy.d.ts","sourceRoot":"","sources":["../../../src/policies/StorageSharedKeyCredentialPolicy.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,aAAa,EACb,wBAAwB,IAAI,oBAAoB,EAChD,eAAe,IAAI,WAAW,EAC/B,MAAM,yBAAyB,CAAC;AACjC,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,8CAA8C,CAAC;AAG/F,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAGzD;;GAEG;AACH,qBAAa,gCAAiC,SAAQ,gBAAgB;IACpE;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA6B;IAErD;;;;;OAKG;gBAED,UAAU,EAAE,aAAa,EACzB,OAAO,EAAE,oBAAoB,EAC7B,OAAO,EAAE,0BAA0B;IAMrC;;;;OAIG;IACH,SAAS,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,WAAW;IA2CxD;;;;;;OAMG;IACH,OAAO,CAAC,oBAAoB;IAiB5B;;;;;;;;;;;;OAYG;IACH,OAAO,CAAC,6BAA6B;IA2BrC;;;;OAIG;IACH,OAAO,CAAC,8BAA8B;CA0BvC"}