@azure/arm-durabletask 1.0.0 → 1.1.0

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 (233) hide show
  1. package/README.md +1 -1
  2. package/dist/browser/api/durableTaskContext.d.ts +3 -3
  3. package/dist/browser/api/durableTaskContext.js +3 -18
  4. package/dist/browser/api/durableTaskContext.js.map +1 -1
  5. package/dist/browser/api/index.d.ts +2 -1
  6. package/dist/browser/api/index.js +1 -1
  7. package/dist/browser/api/index.js.map +1 -1
  8. package/dist/browser/api/operations/index.d.ts +1 -1
  9. package/dist/browser/api/operations/index.js.map +1 -1
  10. package/dist/browser/api/operations/operations.js +3 -6
  11. package/dist/browser/api/operations/operations.js.map +1 -1
  12. package/dist/browser/api/retentionPolicies/index.d.ts +1 -1
  13. package/dist/browser/api/retentionPolicies/index.js.map +1 -1
  14. package/dist/browser/api/retentionPolicies/operations.js +19 -36
  15. package/dist/browser/api/retentionPolicies/operations.js.map +1 -1
  16. package/dist/browser/api/schedulers/index.d.ts +2 -2
  17. package/dist/browser/api/schedulers/index.js +1 -1
  18. package/dist/browser/api/schedulers/index.js.map +1 -1
  19. package/dist/browser/api/schedulers/operations.d.ts +30 -2
  20. package/dist/browser/api/schedulers/operations.js +234 -31
  21. package/dist/browser/api/schedulers/operations.js.map +1 -1
  22. package/dist/browser/api/schedulers/options.d.ts +27 -0
  23. package/dist/browser/api/schedulers/options.js.map +1 -1
  24. package/dist/browser/api/taskHubs/index.d.ts +1 -1
  25. package/dist/browser/api/taskHubs/index.js.map +1 -1
  26. package/dist/browser/api/taskHubs/operations.js +10 -17
  27. package/dist/browser/api/taskHubs/operations.js.map +1 -1
  28. package/dist/browser/classic/index.d.ts +4 -4
  29. package/dist/browser/classic/index.js.map +1 -1
  30. package/dist/browser/classic/schedulers/index.d.ts +16 -2
  31. package/dist/browser/classic/schedulers/index.js +8 -1
  32. package/dist/browser/classic/schedulers/index.js.map +1 -1
  33. package/dist/browser/durableTaskClient.d.ts +1 -1
  34. package/dist/browser/durableTaskClient.js.map +1 -1
  35. package/dist/browser/index.d.ts +16 -12
  36. package/dist/browser/index.js +1 -1
  37. package/dist/browser/index.js.map +1 -1
  38. package/dist/browser/models/index.d.ts +2 -1
  39. package/dist/browser/models/index.js +1 -1
  40. package/dist/browser/models/index.js.map +1 -1
  41. package/dist/browser/models/models.d.ts +166 -10
  42. package/dist/browser/models/models.js +184 -6
  43. package/dist/browser/models/models.js.map +1 -1
  44. package/dist/browser/restorePollerHelpers.js +22 -25
  45. package/dist/browser/restorePollerHelpers.js.map +1 -1
  46. package/dist/browser/static-helpers/pagingHelpers.d.ts +2 -0
  47. package/dist/browser/static-helpers/pagingHelpers.js +28 -3
  48. package/dist/browser/static-helpers/pagingHelpers.js.map +1 -1
  49. package/dist/browser/static-helpers/pollingHelpers.d.ts +4 -0
  50. package/dist/browser/static-helpers/pollingHelpers.js +18 -2
  51. package/dist/browser/static-helpers/pollingHelpers.js.map +1 -1
  52. package/dist/browser/static-helpers/urlTemplate.js +20 -5
  53. package/dist/browser/static-helpers/urlTemplate.js.map +1 -1
  54. package/dist/commonjs/api/durableTaskContext.d.ts +3 -3
  55. package/dist/commonjs/api/durableTaskContext.js +43 -39
  56. package/dist/commonjs/api/durableTaskContext.js.map +7 -1
  57. package/dist/commonjs/api/index.d.ts +2 -1
  58. package/dist/commonjs/api/index.js +28 -8
  59. package/dist/commonjs/api/index.js.map +7 -1
  60. package/dist/commonjs/api/operations/index.d.ts +1 -1
  61. package/dist/commonjs/api/operations/index.js +28 -8
  62. package/dist/commonjs/api/operations/index.js.map +7 -1
  63. package/dist/commonjs/api/operations/operations.js +62 -33
  64. package/dist/commonjs/api/operations/operations.js.map +7 -1
  65. package/dist/commonjs/api/operations/options.js +16 -5
  66. package/dist/commonjs/api/operations/options.js.map +7 -1
  67. package/dist/commonjs/api/retentionPolicies/index.d.ts +1 -1
  68. package/dist/commonjs/api/retentionPolicies/index.js +36 -12
  69. package/dist/commonjs/api/retentionPolicies/index.js.map +7 -1
  70. package/dist/commonjs/api/retentionPolicies/operations.js +210 -176
  71. package/dist/commonjs/api/retentionPolicies/operations.js.map +7 -1
  72. package/dist/commonjs/api/retentionPolicies/options.js +16 -5
  73. package/dist/commonjs/api/retentionPolicies/options.js.map +7 -1
  74. package/dist/commonjs/api/schedulers/index.d.ts +2 -2
  75. package/dist/commonjs/api/schedulers/index.js +52 -13
  76. package/dist/commonjs/api/schedulers/index.js.map +7 -1
  77. package/dist/commonjs/api/schedulers/operations.d.ts +30 -2
  78. package/dist/commonjs/api/schedulers/operations.js +577 -189
  79. package/dist/commonjs/api/schedulers/operations.js.map +7 -1
  80. package/dist/commonjs/api/schedulers/options.d.ts +27 -0
  81. package/dist/commonjs/api/schedulers/options.js +16 -5
  82. package/dist/commonjs/api/schedulers/options.js.map +7 -1
  83. package/dist/commonjs/api/taskHubs/index.d.ts +1 -1
  84. package/dist/commonjs/api/taskHubs/index.js +34 -11
  85. package/dist/commonjs/api/taskHubs/index.js.map +7 -1
  86. package/dist/commonjs/api/taskHubs/operations.js +178 -133
  87. package/dist/commonjs/api/taskHubs/operations.js.map +7 -1
  88. package/dist/commonjs/api/taskHubs/options.js +16 -5
  89. package/dist/commonjs/api/taskHubs/options.js.map +7 -1
  90. package/dist/commonjs/classic/index.d.ts +4 -4
  91. package/dist/commonjs/classic/index.js +16 -5
  92. package/dist/commonjs/classic/index.js.map +7 -1
  93. package/dist/commonjs/classic/operations/index.js +34 -13
  94. package/dist/commonjs/classic/operations/index.js.map +7 -1
  95. package/dist/commonjs/classic/retentionPolicies/index.js +38 -17
  96. package/dist/commonjs/classic/retentionPolicies/index.js.map +7 -1
  97. package/dist/commonjs/classic/schedulers/index.d.ts +16 -2
  98. package/dist/commonjs/classic/schedulers/index.js +72 -18
  99. package/dist/commonjs/classic/schedulers/index.js.map +7 -1
  100. package/dist/commonjs/classic/taskHubs/index.js +37 -16
  101. package/dist/commonjs/classic/taskHubs/index.js.map +7 -1
  102. package/dist/commonjs/durableTaskClient.d.ts +1 -1
  103. package/dist/commonjs/durableTaskClient.js +56 -38
  104. package/dist/commonjs/durableTaskClient.js.map +7 -1
  105. package/dist/commonjs/index.d.ts +16 -12
  106. package/dist/commonjs/index.js +57 -21
  107. package/dist/commonjs/index.js.map +7 -1
  108. package/dist/commonjs/logger.js +29 -8
  109. package/dist/commonjs/logger.js.map +7 -1
  110. package/dist/commonjs/models/index.d.ts +2 -1
  111. package/dist/commonjs/models/index.js +48 -15
  112. package/dist/commonjs/models/index.js.map +7 -1
  113. package/dist/commonjs/models/models.d.ts +166 -10
  114. package/dist/commonjs/models/models.js +560 -370
  115. package/dist/commonjs/models/models.js.map +7 -1
  116. package/dist/commonjs/restorePollerHelpers.js +117 -110
  117. package/dist/commonjs/restorePollerHelpers.js.map +7 -1
  118. package/dist/commonjs/static-helpers/cloudSettingHelpers.js +50 -40
  119. package/dist/commonjs/static-helpers/cloudSettingHelpers.js.map +7 -1
  120. package/dist/commonjs/static-helpers/pagingHelpers.d.ts +2 -0
  121. package/dist/commonjs/static-helpers/pagingHelpers.js +125 -103
  122. package/dist/commonjs/static-helpers/pagingHelpers.js.map +7 -1
  123. package/dist/commonjs/static-helpers/pollingHelpers.d.ts +4 -0
  124. package/dist/commonjs/static-helpers/pollingHelpers.js +95 -76
  125. package/dist/commonjs/static-helpers/pollingHelpers.js.map +7 -1
  126. package/dist/commonjs/static-helpers/urlTemplate.js +167 -158
  127. package/dist/commonjs/static-helpers/urlTemplate.js.map +7 -1
  128. package/dist/commonjs/tsdoc-metadata.json +1 -1
  129. package/dist/esm/api/durableTaskContext.d.ts +3 -3
  130. package/dist/esm/api/durableTaskContext.js +3 -18
  131. package/dist/esm/api/durableTaskContext.js.map +1 -1
  132. package/dist/esm/api/index.d.ts +2 -1
  133. package/dist/esm/api/index.js +1 -1
  134. package/dist/esm/api/index.js.map +1 -1
  135. package/dist/esm/api/operations/index.d.ts +1 -1
  136. package/dist/esm/api/operations/index.js.map +1 -1
  137. package/dist/esm/api/operations/operations.js +3 -6
  138. package/dist/esm/api/operations/operations.js.map +1 -1
  139. package/dist/esm/api/retentionPolicies/index.d.ts +1 -1
  140. package/dist/esm/api/retentionPolicies/index.js.map +1 -1
  141. package/dist/esm/api/retentionPolicies/operations.js +19 -36
  142. package/dist/esm/api/retentionPolicies/operations.js.map +1 -1
  143. package/dist/esm/api/schedulers/index.d.ts +2 -2
  144. package/dist/esm/api/schedulers/index.js +1 -1
  145. package/dist/esm/api/schedulers/index.js.map +1 -1
  146. package/dist/esm/api/schedulers/operations.d.ts +30 -2
  147. package/dist/esm/api/schedulers/operations.js +234 -31
  148. package/dist/esm/api/schedulers/operations.js.map +1 -1
  149. package/dist/esm/api/schedulers/options.d.ts +27 -0
  150. package/dist/esm/api/schedulers/options.js.map +1 -1
  151. package/dist/esm/api/taskHubs/index.d.ts +1 -1
  152. package/dist/esm/api/taskHubs/index.js.map +1 -1
  153. package/dist/esm/api/taskHubs/operations.js +10 -17
  154. package/dist/esm/api/taskHubs/operations.js.map +1 -1
  155. package/dist/esm/classic/index.d.ts +4 -4
  156. package/dist/esm/classic/index.js.map +1 -1
  157. package/dist/esm/classic/schedulers/index.d.ts +16 -2
  158. package/dist/esm/classic/schedulers/index.js +8 -1
  159. package/dist/esm/classic/schedulers/index.js.map +1 -1
  160. package/dist/esm/durableTaskClient.d.ts +1 -1
  161. package/dist/esm/durableTaskClient.js.map +1 -1
  162. package/dist/esm/index.d.ts +16 -12
  163. package/dist/esm/index.js +1 -1
  164. package/dist/esm/index.js.map +1 -1
  165. package/dist/esm/models/index.d.ts +2 -1
  166. package/dist/esm/models/index.js +1 -1
  167. package/dist/esm/models/index.js.map +1 -1
  168. package/dist/esm/models/models.d.ts +166 -10
  169. package/dist/esm/models/models.js +184 -6
  170. package/dist/esm/models/models.js.map +1 -1
  171. package/dist/esm/restorePollerHelpers.js +22 -25
  172. package/dist/esm/restorePollerHelpers.js.map +1 -1
  173. package/dist/esm/static-helpers/pagingHelpers.d.ts +2 -0
  174. package/dist/esm/static-helpers/pagingHelpers.js +28 -3
  175. package/dist/esm/static-helpers/pagingHelpers.js.map +1 -1
  176. package/dist/esm/static-helpers/pollingHelpers.d.ts +4 -0
  177. package/dist/esm/static-helpers/pollingHelpers.js +18 -2
  178. package/dist/esm/static-helpers/pollingHelpers.js.map +1 -1
  179. package/dist/esm/static-helpers/urlTemplate.js +20 -5
  180. package/dist/esm/static-helpers/urlTemplate.js.map +1 -1
  181. package/dist/react-native/api/durableTaskContext.d.ts +3 -3
  182. package/dist/react-native/api/durableTaskContext.js +3 -18
  183. package/dist/react-native/api/durableTaskContext.js.map +1 -1
  184. package/dist/react-native/api/index.d.ts +2 -1
  185. package/dist/react-native/api/index.js +1 -1
  186. package/dist/react-native/api/index.js.map +1 -1
  187. package/dist/react-native/api/operations/index.d.ts +1 -1
  188. package/dist/react-native/api/operations/index.js.map +1 -1
  189. package/dist/react-native/api/operations/operations.js +3 -6
  190. package/dist/react-native/api/operations/operations.js.map +1 -1
  191. package/dist/react-native/api/retentionPolicies/index.d.ts +1 -1
  192. package/dist/react-native/api/retentionPolicies/index.js.map +1 -1
  193. package/dist/react-native/api/retentionPolicies/operations.js +19 -36
  194. package/dist/react-native/api/retentionPolicies/operations.js.map +1 -1
  195. package/dist/react-native/api/schedulers/index.d.ts +2 -2
  196. package/dist/react-native/api/schedulers/index.js +1 -1
  197. package/dist/react-native/api/schedulers/index.js.map +1 -1
  198. package/dist/react-native/api/schedulers/operations.d.ts +30 -2
  199. package/dist/react-native/api/schedulers/operations.js +234 -31
  200. package/dist/react-native/api/schedulers/operations.js.map +1 -1
  201. package/dist/react-native/api/schedulers/options.d.ts +27 -0
  202. package/dist/react-native/api/schedulers/options.js.map +1 -1
  203. package/dist/react-native/api/taskHubs/index.d.ts +1 -1
  204. package/dist/react-native/api/taskHubs/index.js.map +1 -1
  205. package/dist/react-native/api/taskHubs/operations.js +10 -17
  206. package/dist/react-native/api/taskHubs/operations.js.map +1 -1
  207. package/dist/react-native/classic/index.d.ts +4 -4
  208. package/dist/react-native/classic/index.js.map +1 -1
  209. package/dist/react-native/classic/schedulers/index.d.ts +16 -2
  210. package/dist/react-native/classic/schedulers/index.js +8 -1
  211. package/dist/react-native/classic/schedulers/index.js.map +1 -1
  212. package/dist/react-native/durableTaskClient.d.ts +1 -1
  213. package/dist/react-native/durableTaskClient.js.map +1 -1
  214. package/dist/react-native/index.d.ts +16 -12
  215. package/dist/react-native/index.js +1 -1
  216. package/dist/react-native/index.js.map +1 -1
  217. package/dist/react-native/models/index.d.ts +2 -1
  218. package/dist/react-native/models/index.js +1 -1
  219. package/dist/react-native/models/index.js.map +1 -1
  220. package/dist/react-native/models/models.d.ts +166 -10
  221. package/dist/react-native/models/models.js +184 -6
  222. package/dist/react-native/models/models.js.map +1 -1
  223. package/dist/react-native/restorePollerHelpers.js +22 -25
  224. package/dist/react-native/restorePollerHelpers.js.map +1 -1
  225. package/dist/react-native/static-helpers/pagingHelpers.d.ts +2 -0
  226. package/dist/react-native/static-helpers/pagingHelpers.js +28 -3
  227. package/dist/react-native/static-helpers/pagingHelpers.js.map +1 -1
  228. package/dist/react-native/static-helpers/pollingHelpers.d.ts +4 -0
  229. package/dist/react-native/static-helpers/pollingHelpers.js +18 -2
  230. package/dist/react-native/static-helpers/pollingHelpers.js.map +1 -1
  231. package/dist/react-native/static-helpers/urlTemplate.js +20 -5
  232. package/dist/react-native/static-helpers/urlTemplate.js.map +1 -1
  233. package/package.json +50 -59
@@ -1,42 +1,52 @@
1
- "use strict";
2
- // Copyright (c) Microsoft Corporation.
3
- // Licensed under the MIT License.
4
- Object.defineProperty(exports, "__esModule", { value: true });
5
- exports.AzureClouds = void 0;
6
- exports.getArmEndpoint = getArmEndpoint;
7
- /**
8
- * An enum to describe Azure Cloud environments.
9
- * @enum {string}
10
- */
11
- var AzureClouds;
12
- (function (AzureClouds) {
13
- /** Azure public cloud, which is the default cloud for Azure SDKs. */
14
- AzureClouds["AZURE_PUBLIC_CLOUD"] = "AZURE_PUBLIC_CLOUD";
15
- /** Azure China cloud */
16
- AzureClouds["AZURE_CHINA_CLOUD"] = "AZURE_CHINA_CLOUD";
17
- /** Azure US government cloud */
18
- AzureClouds["AZURE_US_GOVERNMENT"] = "AZURE_US_GOVERNMENT";
19
- })(AzureClouds || (exports.AzureClouds = AzureClouds = {}));
20
- /**
21
- * Gets the Azure Resource Manager endpoint URL for the specified cloud setting.
22
- * @param cloudSetting - The Azure cloud environment setting. Use one of the AzureClouds enum values.
23
- * @returns The ARM endpoint URL for the specified cloud, or undefined if cloudSetting is undefined.
24
- * @throws {Error} Throws an error if an unknown cloud setting is provided.
25
- */
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var cloudSettingHelpers_exports = {};
19
+ __export(cloudSettingHelpers_exports, {
20
+ AzureClouds: () => AzureClouds,
21
+ getArmEndpoint: () => getArmEndpoint
22
+ });
23
+ module.exports = __toCommonJS(cloudSettingHelpers_exports);
24
+ var AzureClouds = /* @__PURE__ */ ((AzureClouds2) => {
25
+ AzureClouds2["AZURE_PUBLIC_CLOUD"] = "AZURE_PUBLIC_CLOUD";
26
+ AzureClouds2["AZURE_CHINA_CLOUD"] = "AZURE_CHINA_CLOUD";
27
+ AzureClouds2["AZURE_US_GOVERNMENT"] = "AZURE_US_GOVERNMENT";
28
+ return AzureClouds2;
29
+ })(AzureClouds || {});
26
30
  function getArmEndpoint(cloudSetting) {
27
- if (cloudSetting === undefined) {
28
- return undefined;
29
- }
30
- const cloudEndpoints = {
31
- AZURE_CHINA_CLOUD: "https://management.chinacloudapi.cn/",
32
- AZURE_US_GOVERNMENT: "https://management.usgovcloudapi.net/",
33
- AZURE_PUBLIC_CLOUD: "https://management.azure.com/",
34
- };
35
- if (cloudSetting in cloudEndpoints) {
36
- return cloudEndpoints[cloudSetting];
37
- }
38
- else {
39
- throw new Error(`Unknown cloud setting: ${cloudSetting}. Please refer to the enum AzureClouds for possible values.`);
40
- }
31
+ if (cloudSetting === void 0) {
32
+ return void 0;
33
+ }
34
+ const cloudEndpoints = {
35
+ AZURE_CHINA_CLOUD: "https://management.chinacloudapi.cn/",
36
+ AZURE_US_GOVERNMENT: "https://management.usgovcloudapi.net/",
37
+ AZURE_PUBLIC_CLOUD: "https://management.azure.com/"
38
+ };
39
+ if (cloudSetting in cloudEndpoints) {
40
+ return cloudEndpoints[cloudSetting];
41
+ } else {
42
+ throw new Error(
43
+ `Unknown cloud setting: ${cloudSetting}. Please refer to the enum AzureClouds for possible values.`
44
+ );
45
+ }
41
46
  }
42
- //# sourceMappingURL=cloudSettingHelpers.js.map
47
+ // Annotate the CommonJS export names for ESM import in node:
48
+ 0 && (module.exports = {
49
+ AzureClouds,
50
+ getArmEndpoint
51
+ });
52
+ //# sourceMappingURL=cloudSettingHelpers.js.map
@@ -1 +1,7 @@
1
- {"version":3,"file":"cloudSettingHelpers.js","sourceRoot":"","sources":["../../../src/static-helpers/cloudSettingHelpers.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;AAwBlC,wCAgBC;AAtCD;;;GAGG;AACH,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,qEAAqE;IACrE,wDAAyC,CAAA;IACzC,wBAAwB;IACxB,sDAAuC,CAAA;IACvC,gCAAgC;IAChC,0DAA2C,CAAA;AAC7C,CAAC,EAPW,WAAW,2BAAX,WAAW,QAOtB;AAKD;;;;;GAKG;AACH,SAAgB,cAAc,CAAC,YAAmC;IAChE,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;QAC/B,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,cAAc,GAA6C;QAC/D,iBAAiB,EAAE,sCAAsC;QACzD,mBAAmB,EAAE,uCAAuC;QAC5D,kBAAkB,EAAE,+BAA+B;KACpD,CAAC;IACF,IAAI,YAAY,IAAI,cAAc,EAAE,CAAC;QACnC,OAAO,cAAc,CAAC,YAAY,CAAC,CAAC;IACtC,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,KAAK,CACb,0BAA0B,YAAY,6DAA6D,CACpG,CAAC;IACJ,CAAC;AACH,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * An enum to describe Azure Cloud environments.\n * @enum {string}\n */\nexport enum AzureClouds {\n /** Azure public cloud, which is the default cloud for Azure SDKs. */\n AZURE_PUBLIC_CLOUD = \"AZURE_PUBLIC_CLOUD\",\n /** Azure China cloud */\n AZURE_CHINA_CLOUD = \"AZURE_CHINA_CLOUD\",\n /** Azure US government cloud */\n AZURE_US_GOVERNMENT = \"AZURE_US_GOVERNMENT\",\n}\n\n/** The supported values for cloud setting as a string literal type */\nexport type AzureSupportedClouds = `${AzureClouds}`;\n\n/**\n * Gets the Azure Resource Manager endpoint URL for the specified cloud setting.\n * @param cloudSetting - The Azure cloud environment setting. Use one of the AzureClouds enum values.\n * @returns The ARM endpoint URL for the specified cloud, or undefined if cloudSetting is undefined.\n * @throws {Error} Throws an error if an unknown cloud setting is provided.\n */\nexport function getArmEndpoint(cloudSetting?: AzureSupportedClouds): string | undefined {\n if (cloudSetting === undefined) {\n return undefined;\n }\n const cloudEndpoints: Record<keyof typeof AzureClouds, string> = {\n AZURE_CHINA_CLOUD: \"https://management.chinacloudapi.cn/\",\n AZURE_US_GOVERNMENT: \"https://management.usgovcloudapi.net/\",\n AZURE_PUBLIC_CLOUD: \"https://management.azure.com/\",\n };\n if (cloudSetting in cloudEndpoints) {\n return cloudEndpoints[cloudSetting];\n } else {\n throw new Error(\n `Unknown cloud setting: ${cloudSetting}. Please refer to the enum AzureClouds for possible values.`,\n );\n }\n}\n"]}
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/static-helpers/cloudSettingHelpers.ts"],
4
+ "sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * An enum to describe Azure Cloud environments.\n * @enum {string}\n */\nexport enum AzureClouds {\n /** Azure public cloud, which is the default cloud for Azure SDKs. */\n AZURE_PUBLIC_CLOUD = \"AZURE_PUBLIC_CLOUD\",\n /** Azure China cloud */\n AZURE_CHINA_CLOUD = \"AZURE_CHINA_CLOUD\",\n /** Azure US government cloud */\n AZURE_US_GOVERNMENT = \"AZURE_US_GOVERNMENT\",\n}\n\n/** The supported values for cloud setting as a string literal type */\nexport type AzureSupportedClouds = `${AzureClouds}`;\n\n/**\n * Gets the Azure Resource Manager endpoint URL for the specified cloud setting.\n * @param cloudSetting - The Azure cloud environment setting. Use one of the AzureClouds enum values.\n * @returns The ARM endpoint URL for the specified cloud, or undefined if cloudSetting is undefined.\n * @throws {Error} Throws an error if an unknown cloud setting is provided.\n */\nexport function getArmEndpoint(cloudSetting?: AzureSupportedClouds): string | undefined {\n if (cloudSetting === undefined) {\n return undefined;\n }\n const cloudEndpoints: Record<keyof typeof AzureClouds, string> = {\n AZURE_CHINA_CLOUD: \"https://management.chinacloudapi.cn/\",\n AZURE_US_GOVERNMENT: \"https://management.usgovcloudapi.net/\",\n AZURE_PUBLIC_CLOUD: \"https://management.azure.com/\",\n };\n if (cloudSetting in cloudEndpoints) {\n return cloudEndpoints[cloudSetting];\n } else {\n throw new Error(\n `Unknown cloud setting: ${cloudSetting}. Please refer to the enum AzureClouds for possible values.`,\n );\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOO,IAAK,cAAL,kBAAKA,iBAAL;AAEL,EAAAA,aAAA,wBAAqB;AAErB,EAAAA,aAAA,uBAAoB;AAEpB,EAAAA,aAAA,yBAAsB;AANZ,SAAAA;AAAA,GAAA;AAkBL,SAAS,eAAe,cAAyD;AACtF,MAAI,iBAAiB,QAAW;AAC9B,WAAO;AAAA,EACT;AACA,QAAM,iBAA2D;AAAA,IAC/D,mBAAmB;AAAA,IACnB,qBAAqB;AAAA,IACrB,oBAAoB;AAAA,EACtB;AACA,MAAI,gBAAgB,gBAAgB;AAClC,WAAO,eAAe,YAAY;AAAA,EACpC,OAAO;AACL,UAAM,IAAI;AAAA,MACR,0BAA0B,YAAY;AAAA,IACxC;AAAA,EACF;AACF;",
6
+ "names": ["AzureClouds"]
7
+ }
@@ -64,6 +64,8 @@ export interface PagedResult<TElement, TPage = TElement[], TPageSettings extends
64
64
  export interface BuildPagedAsyncIteratorOptions {
65
65
  itemName?: string;
66
66
  nextLinkName?: string;
67
+ nextLinkMethod?: "GET" | "POST";
68
+ apiVersion?: string;
67
69
  }
68
70
  /**
69
71
  * Helper to paginate results in a generic way and return a PagedAsyncIterableIterator
@@ -1,121 +1,143 @@
1
- "use strict";
2
- // Copyright (c) Microsoft Corporation.
3
- // Licensed under the MIT License.
4
- Object.defineProperty(exports, "__esModule", { value: true });
5
- exports.buildPagedAsyncIterator = buildPagedAsyncIterator;
6
- const core_client_1 = require("@azure-rest/core-client");
7
- const core_rest_pipeline_1 = require("@azure/core-rest-pipeline");
8
- /**
9
- * Helper to paginate results in a generic way and return a PagedAsyncIterableIterator
10
- */
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var pagingHelpers_exports = {};
19
+ __export(pagingHelpers_exports, {
20
+ buildPagedAsyncIterator: () => buildPagedAsyncIterator
21
+ });
22
+ module.exports = __toCommonJS(pagingHelpers_exports);
23
+ var import_core_client = require("@azure-rest/core-client");
24
+ var import_core_rest_pipeline = require("@azure/core-rest-pipeline");
11
25
  function buildPagedAsyncIterator(client, getInitialResponse, processResponseBody, expectedStatuses, options = {}) {
12
- const itemName = options.itemName ?? "value";
13
- const nextLinkName = options.nextLinkName ?? "nextLink";
14
- const pagedResult = {
15
- getPage: async (pageLink) => {
16
- const result = pageLink === undefined
17
- ? await getInitialResponse()
18
- : await client.pathUnchecked(pageLink).get();
19
- checkPagingRequest(result, expectedStatuses);
20
- const results = await processResponseBody(result);
21
- const nextLink = getNextLink(results, nextLinkName);
22
- const values = getElements(results, itemName);
23
- return {
24
- page: values,
25
- nextPageLink: nextLink,
26
- };
27
- },
28
- byPage: (settings) => {
29
- const { continuationToken } = settings ?? {};
30
- return getPageAsyncIterator(pagedResult, {
31
- pageLink: continuationToken,
32
- });
33
- },
34
- };
35
- return getPagedAsyncIterator(pagedResult);
26
+ const itemName = options.itemName ?? "value";
27
+ const nextLinkName = options.nextLinkName ?? "nextLink";
28
+ const nextLinkMethod = options.nextLinkMethod ?? "GET";
29
+ const apiVersion = options.apiVersion;
30
+ const pagedResult = {
31
+ getPage: async (pageLink) => {
32
+ let result;
33
+ if (pageLink === void 0) {
34
+ result = await getInitialResponse();
35
+ } else {
36
+ const resolvedPageLink = apiVersion ? addApiVersionToUrl(pageLink, apiVersion) : pageLink;
37
+ result = nextLinkMethod === "POST" ? await client.pathUnchecked(resolvedPageLink).post() : await client.pathUnchecked(resolvedPageLink).get();
38
+ }
39
+ checkPagingRequest(result, expectedStatuses);
40
+ const results = await processResponseBody(result);
41
+ const nextLink = getNextLink(results, nextLinkName);
42
+ const values = getElements(results, itemName);
43
+ return {
44
+ page: values,
45
+ nextPageLink: nextLink
46
+ };
47
+ },
48
+ byPage: (settings) => {
49
+ const { continuationToken } = settings ?? {};
50
+ return getPageAsyncIterator(pagedResult, {
51
+ pageLink: continuationToken
52
+ });
53
+ }
54
+ };
55
+ return getPagedAsyncIterator(pagedResult);
36
56
  }
37
- /**
38
- * returns an async iterator that iterates over results. It also has a `byPage`
39
- * method that returns pages of items at once.
40
- *
41
- * @param pagedResult - an object that specifies how to get pages.
42
- * @returns a paged async iterator that iterates over results.
43
- */
44
57
  function getPagedAsyncIterator(pagedResult) {
45
- const iter = getItemAsyncIterator(pagedResult);
46
- return {
47
- next() {
48
- return iter.next();
49
- },
50
- [Symbol.asyncIterator]() {
51
- return this;
52
- },
53
- byPage: pagedResult?.byPage ??
54
- ((settings) => {
55
- const { continuationToken } = settings ?? {};
56
- return getPageAsyncIterator(pagedResult, {
57
- pageLink: continuationToken,
58
- });
59
- }),
60
- };
58
+ const iter = getItemAsyncIterator(pagedResult);
59
+ return {
60
+ next() {
61
+ return iter.next();
62
+ },
63
+ [Symbol.asyncIterator]() {
64
+ return this;
65
+ },
66
+ byPage: pagedResult?.byPage ?? ((settings) => {
67
+ const { continuationToken } = settings ?? {};
68
+ return getPageAsyncIterator(pagedResult, {
69
+ pageLink: continuationToken
70
+ });
71
+ })
72
+ };
61
73
  }
62
74
  async function* getItemAsyncIterator(pagedResult) {
63
- const pages = getPageAsyncIterator(pagedResult);
64
- for await (const page of pages) {
65
- yield* page;
66
- }
75
+ const pages = getPageAsyncIterator(pagedResult);
76
+ for await (const page of pages) {
77
+ yield* page;
78
+ }
67
79
  }
68
80
  async function* getPageAsyncIterator(pagedResult, options = {}) {
69
- const { pageLink } = options;
70
- let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);
81
+ const { pageLink } = options;
82
+ let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);
83
+ if (!response) {
84
+ return;
85
+ }
86
+ let result = response.page;
87
+ result.continuationToken = response.nextPageLink;
88
+ yield result;
89
+ while (response.nextPageLink) {
90
+ response = await pagedResult.getPage(response.nextPageLink);
71
91
  if (!response) {
72
- return;
92
+ return;
73
93
  }
74
- let result = response.page;
94
+ result = response.page;
75
95
  result.continuationToken = response.nextPageLink;
76
96
  yield result;
77
- while (response.nextPageLink) {
78
- response = await pagedResult.getPage(response.nextPageLink);
79
- if (!response) {
80
- return;
81
- }
82
- result = response.page;
83
- result.continuationToken = response.nextPageLink;
84
- yield result;
85
- }
97
+ }
86
98
  }
87
- /**
88
- * Gets for the value of nextLink in the body
89
- */
90
99
  function getNextLink(body, nextLinkName) {
91
- if (!nextLinkName) {
92
- return undefined;
93
- }
94
- const nextLink = body[nextLinkName];
95
- if (typeof nextLink !== "string" && typeof nextLink !== "undefined" && nextLink !== null) {
96
- throw new core_rest_pipeline_1.RestError(`Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`);
97
- }
98
- if (nextLink === null) {
99
- return undefined;
100
- }
101
- return nextLink;
100
+ if (!nextLinkName) {
101
+ return void 0;
102
+ }
103
+ const nextLink = body[nextLinkName];
104
+ if (typeof nextLink !== "string" && typeof nextLink !== "undefined" && nextLink !== null) {
105
+ throw new import_core_rest_pipeline.RestError(
106
+ `Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`
107
+ );
108
+ }
109
+ if (nextLink === null) {
110
+ return void 0;
111
+ }
112
+ return nextLink;
102
113
  }
103
- /**
104
- * Gets the elements of the current request in the body.
105
- */
106
114
  function getElements(body, itemName) {
107
- const value = body[itemName];
108
- if (!Array.isArray(value)) {
109
- throw new core_rest_pipeline_1.RestError(`Couldn't paginate response\n Body doesn't contain an array property with name: ${itemName}`);
110
- }
111
- return value ?? [];
115
+ const value = body[itemName];
116
+ if (!Array.isArray(value)) {
117
+ throw new import_core_rest_pipeline.RestError(
118
+ `Couldn't paginate response
119
+ Body doesn't contain an array property with name: ${itemName}`
120
+ );
121
+ }
122
+ return value ?? [];
112
123
  }
113
- /**
114
- * Checks if a request failed
115
- */
116
124
  function checkPagingRequest(response, expectedStatuses) {
117
- if (!expectedStatuses.includes(response.status)) {
118
- throw (0, core_client_1.createRestError)(`Pagination failed with unexpected statusCode ${response.status}`, response);
119
- }
125
+ if (!expectedStatuses.includes(response.status)) {
126
+ throw (0, import_core_client.createRestError)(
127
+ `Pagination failed with unexpected statusCode ${response.status}`,
128
+ response
129
+ );
130
+ }
131
+ }
132
+ function addApiVersionToUrl(url, apiVersion) {
133
+ const urlObj = new URL(url, "https://microsoft.com");
134
+ if (!urlObj.searchParams.get("api-version")) {
135
+ return `${url}${Array.from(urlObj.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
136
+ }
137
+ return url;
120
138
  }
121
- //# sourceMappingURL=pagingHelpers.js.map
139
+ // Annotate the CommonJS export names for ESM import in node:
140
+ 0 && (module.exports = {
141
+ buildPagedAsyncIterator
142
+ });
143
+ //# sourceMappingURL=pagingHelpers.js.map
@@ -1 +1,7 @@
1
- {"version":3,"file":"pagingHelpers.js","sourceRoot":"","sources":["../../../src/static-helpers/pagingHelpers.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;AAsFlC,0DAqCC;AAxHD,yDAA0D;AAC1D,kEAAsD;AA+EtD;;GAEG;AACH,SAAgB,uBAAuB,CAMrC,MAAc,EACd,kBAAgD,EAChD,mBAAgE,EAChE,gBAA0B,EAC1B,UAA0C,EAAE;IAE5C,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC;IAC7C,MAAM,YAAY,GAAG,OAAO,CAAC,YAAY,IAAI,UAAU,CAAC;IACxD,MAAM,WAAW,GAAgD;QAC/D,OAAO,EAAE,KAAK,EAAE,QAAiB,EAAE,EAAE;YACnC,MAAM,MAAM,GACV,QAAQ,KAAK,SAAS;gBACpB,CAAC,CAAC,MAAM,kBAAkB,EAAE;gBAC5B,CAAC,CAAC,MAAM,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;YACjD,kBAAkB,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;YAC7C,MAAM,OAAO,GAAG,MAAM,mBAAmB,CAAC,MAAmB,CAAC,CAAC;YAC/D,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;YACpD,MAAM,MAAM,GAAG,WAAW,CAAW,OAAO,EAAE,QAAQ,CAAU,CAAC;YACjE,OAAO;gBACL,IAAI,EAAE,MAAM;gBACZ,YAAY,EAAE,QAAQ;aACvB,CAAC;QACJ,CAAC;QACD,MAAM,EAAE,CAAC,QAAwB,EAAE,EAAE;YACnC,MAAM,EAAE,iBAAiB,EAAE,GAAG,QAAQ,IAAI,EAAE,CAAC;YAC7C,OAAO,oBAAoB,CAAC,WAAW,EAAE;gBACvC,QAAQ,EAAE,iBAAiB;aAC5B,CAAC,CAAC;QACL,CAAC;KACF,CAAC;IACF,OAAO,qBAAqB,CAAC,WAAW,CAAC,CAAC;AAC5C,CAAC;AAED;;;;;;GAMG;AAEH,SAAS,qBAAqB,CAK5B,WAAwD;IAExD,MAAM,IAAI,GAAG,oBAAoB,CAAiC,WAAW,CAAC,CAAC;IAC/E,OAAO;QACL,IAAI;YACF,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC;QACrB,CAAC;QACD,CAAC,MAAM,CAAC,aAAa,CAAC;YACpB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,EACJ,WAAW,EAAE,MAAM;YACnB,CAAC,CAAC,QAAwB,EAAE,EAAE;gBAC5B,MAAM,EAAE,iBAAiB,EAAE,GAAG,QAAQ,IAAI,EAAE,CAAC;gBAC7C,OAAO,oBAAoB,CAAC,WAAW,EAAE;oBACvC,QAAQ,EAAE,iBAAiB;iBAC5B,CAAC,CAAC;YACL,CAAC,CAAC;KACL,CAAC;AACJ,CAAC;AAED,KAAK,SAAS,CAAC,CAAC,oBAAoB,CAClC,WAAwD;IAExD,MAAM,KAAK,GAAG,oBAAoB,CAAC,WAAW,CAAC,CAAC;IAChD,IAAI,KAAK,EAAE,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QAC/B,KAAK,CAAC,CAAC,IAA6B,CAAC;IACvC,CAAC;AACH,CAAC;AAED,KAAK,SAAS,CAAC,CAAC,oBAAoB,CAClC,WAAwD,EACxD,UAEI,EAAE;IAEN,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IAC7B,IAAI,QAAQ,GAAG,MAAM,WAAW,CAAC,OAAO,CAAC,QAAQ,IAAI,WAAW,CAAC,aAAa,CAAC,CAAC;IAChF,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,OAAO;IACT,CAAC;IACD,IAAI,MAAM,GAAG,QAAQ,CAAC,IAAwC,CAAC;IAC/D,MAAM,CAAC,iBAAiB,GAAG,QAAQ,CAAC,YAAY,CAAC;IACjD,MAAM,MAAM,CAAC;IACb,OAAO,QAAQ,CAAC,YAAY,EAAE,CAAC;QAC7B,QAAQ,GAAG,MAAM,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,OAAO;QACT,CAAC;QACD,MAAM,GAAG,QAAQ,CAAC,IAAwC,CAAC;QAC3D,MAAM,CAAC,iBAAiB,GAAG,QAAQ,CAAC,YAAY,CAAC;QACjD,MAAM,MAAM,CAAC;IACf,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAS,WAAW,CAAC,IAAa,EAAE,YAAqB;IACvD,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,QAAQ,GAAI,IAAgC,CAAC,YAAY,CAAC,CAAC;IAEjE,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,OAAO,QAAQ,KAAK,WAAW,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;QACzF,MAAM,IAAI,8BAAS,CACjB,iBAAiB,YAAY,oDAAoD,OAAO,QAAQ,EAAE,CACnG,CAAC;IACJ,CAAC;IAED,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;QACtB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,SAAS,WAAW,CAAc,IAAa,EAAE,QAAgB;IAC/D,MAAM,KAAK,GAAI,IAAgC,CAAC,QAAQ,CAAQ,CAAC;IACjE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,MAAM,IAAI,8BAAS,CACjB,kFAAkF,QAAQ,EAAE,CAC7F,CAAC;IACJ,CAAC;IAED,OAAO,KAAK,IAAI,EAAE,CAAC;AACrB,CAAC;AAED;;GAEG;AACH,SAAS,kBAAkB,CAAC,QAA+B,EAAE,gBAA0B;IACrF,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAChD,MAAM,IAAA,6BAAe,EACnB,gDAAgD,QAAQ,CAAC,MAAM,EAAE,EACjE,QAAQ,CACT,CAAC;IACJ,CAAC;AACH,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { Client, PathUncheckedResponse } from \"@azure-rest/core-client\";\nimport { createRestError } from \"@azure-rest/core-client\";\nimport { RestError } from \"@azure/core-rest-pipeline\";\n\n/**\n * Options for the byPage method\n */\nexport interface PageSettings {\n /**\n * A reference to a specific page to start iterating from.\n */\n continuationToken?: string;\n}\n\n/**\n * An interface that describes a page of results.\n */\nexport type ContinuablePage<TElement, TPage = TElement[]> = TPage & {\n /**\n * The token that keeps track of where to continue the iterator\n */\n continuationToken?: string;\n};\n\n/**\n * An interface that allows async iterable iteration both to completion and by page.\n */\nexport interface PagedAsyncIterableIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n> {\n /**\n * The next method, part of the iteration protocol\n */\n next(): Promise<IteratorResult<TElement>>;\n /**\n * The connection to the async iterator, part of the iteration protocol\n */\n [Symbol.asyncIterator](): PagedAsyncIterableIterator<TElement, TPage, TPageSettings>;\n /**\n * Return an AsyncIterableIterator that works a page at a time\n */\n byPage: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;\n}\n\n/**\n * An interface that describes how to communicate with the service.\n */\nexport interface PagedResult<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n> {\n /**\n * Link to the first page of results.\n */\n firstPageLink?: string;\n /**\n * A method that returns a page of results.\n */\n getPage: (pageLink?: string) => Promise<{ page: TPage; nextPageLink?: string } | undefined>;\n /**\n * a function to implement the `byPage` method on the paged async iterator.\n */\n byPage?: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;\n\n /**\n * A function to extract elements from a page.\n */\n toElements?: (page: TPage) => TElement[];\n}\n\n/**\n * Options for the paging helper\n */\nexport interface BuildPagedAsyncIteratorOptions {\n itemName?: string;\n nextLinkName?: string;\n}\n\n/**\n * Helper to paginate results in a generic way and return a PagedAsyncIterableIterator\n */\nexport function buildPagedAsyncIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n TResponse extends PathUncheckedResponse = PathUncheckedResponse,\n>(\n client: Client,\n getInitialResponse: () => PromiseLike<TResponse>,\n processResponseBody: (result: TResponse) => PromiseLike<unknown>,\n expectedStatuses: string[],\n options: BuildPagedAsyncIteratorOptions = {},\n): PagedAsyncIterableIterator<TElement, TPage, TPageSettings> {\n const itemName = options.itemName ?? \"value\";\n const nextLinkName = options.nextLinkName ?? \"nextLink\";\n const pagedResult: PagedResult<TElement, TPage, TPageSettings> = {\n getPage: async (pageLink?: string) => {\n const result =\n pageLink === undefined\n ? await getInitialResponse()\n : await client.pathUnchecked(pageLink).get();\n checkPagingRequest(result, expectedStatuses);\n const results = await processResponseBody(result as TResponse);\n const nextLink = getNextLink(results, nextLinkName);\n const values = getElements<TElement>(results, itemName) as TPage;\n return {\n page: values,\n nextPageLink: nextLink,\n };\n },\n byPage: (settings?: TPageSettings) => {\n const { continuationToken } = settings ?? {};\n return getPageAsyncIterator(pagedResult, {\n pageLink: continuationToken,\n });\n },\n };\n return getPagedAsyncIterator(pagedResult);\n}\n\n/**\n * returns an async iterator that iterates over results. It also has a `byPage`\n * method that returns pages of items at once.\n *\n * @param pagedResult - an object that specifies how to get pages.\n * @returns a paged async iterator that iterates over results.\n */\n\nfunction getPagedAsyncIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n): PagedAsyncIterableIterator<TElement, TPage, TPageSettings> {\n const iter = getItemAsyncIterator<TElement, TPage, TPageSettings>(pagedResult);\n return {\n next() {\n return iter.next();\n },\n [Symbol.asyncIterator]() {\n return this;\n },\n byPage:\n pagedResult?.byPage ??\n ((settings?: TPageSettings) => {\n const { continuationToken } = settings ?? {};\n return getPageAsyncIterator(pagedResult, {\n pageLink: continuationToken,\n });\n }),\n };\n}\n\nasync function* getItemAsyncIterator<TElement, TPage, TPageSettings extends PageSettings>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n): AsyncIterableIterator<TElement> {\n const pages = getPageAsyncIterator(pagedResult);\n for await (const page of pages) {\n yield* page as unknown as TElement[];\n }\n}\n\nasync function* getPageAsyncIterator<TElement, TPage, TPageSettings extends PageSettings>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n options: {\n pageLink?: string;\n } = {},\n): AsyncIterableIterator<ContinuablePage<TElement, TPage>> {\n const { pageLink } = options;\n let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);\n if (!response) {\n return;\n }\n let result = response.page as ContinuablePage<TElement, TPage>;\n result.continuationToken = response.nextPageLink;\n yield result;\n while (response.nextPageLink) {\n response = await pagedResult.getPage(response.nextPageLink);\n if (!response) {\n return;\n }\n result = response.page as ContinuablePage<TElement, TPage>;\n result.continuationToken = response.nextPageLink;\n yield result;\n }\n}\n\n/**\n * Gets for the value of nextLink in the body\n */\nfunction getNextLink(body: unknown, nextLinkName?: string): string | undefined {\n if (!nextLinkName) {\n return undefined;\n }\n\n const nextLink = (body as Record<string, unknown>)[nextLinkName];\n\n if (typeof nextLink !== \"string\" && typeof nextLink !== \"undefined\" && nextLink !== null) {\n throw new RestError(\n `Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`,\n );\n }\n\n if (nextLink === null) {\n return undefined;\n }\n\n return nextLink;\n}\n\n/**\n * Gets the elements of the current request in the body.\n */\nfunction getElements<T = unknown>(body: unknown, itemName: string): T[] {\n const value = (body as Record<string, unknown>)[itemName] as T[];\n if (!Array.isArray(value)) {\n throw new RestError(\n `Couldn't paginate response\\n Body doesn't contain an array property with name: ${itemName}`,\n );\n }\n\n return value ?? [];\n}\n\n/**\n * Checks if a request failed\n */\nfunction checkPagingRequest(response: PathUncheckedResponse, expectedStatuses: string[]): void {\n if (!expectedStatuses.includes(response.status)) {\n throw createRestError(\n `Pagination failed with unexpected statusCode ${response.status}`,\n response,\n );\n }\n}\n"]}
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/static-helpers/pagingHelpers.ts"],
4
+ "sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { Client, PathUncheckedResponse } from \"@azure-rest/core-client\";\nimport { createRestError } from \"@azure-rest/core-client\";\nimport { RestError } from \"@azure/core-rest-pipeline\";\n\n/**\n * Options for the byPage method\n */\nexport interface PageSettings {\n /**\n * A reference to a specific page to start iterating from.\n */\n continuationToken?: string;\n}\n\n/**\n * An interface that describes a page of results.\n */\nexport type ContinuablePage<TElement, TPage = TElement[]> = TPage & {\n /**\n * The token that keeps track of where to continue the iterator\n */\n continuationToken?: string;\n};\n\n/**\n * An interface that allows async iterable iteration both to completion and by page.\n */\nexport interface PagedAsyncIterableIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n> {\n /**\n * The next method, part of the iteration protocol\n */\n next(): Promise<IteratorResult<TElement>>;\n /**\n * The connection to the async iterator, part of the iteration protocol\n */\n [Symbol.asyncIterator](): PagedAsyncIterableIterator<TElement, TPage, TPageSettings>;\n /**\n * Return an AsyncIterableIterator that works a page at a time\n */\n byPage: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;\n}\n\n/**\n * An interface that describes how to communicate with the service.\n */\nexport interface PagedResult<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n> {\n /**\n * Link to the first page of results.\n */\n firstPageLink?: string;\n /**\n * A method that returns a page of results.\n */\n getPage: (pageLink?: string) => Promise<{ page: TPage; nextPageLink?: string } | undefined>;\n /**\n * a function to implement the `byPage` method on the paged async iterator.\n */\n byPage?: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;\n\n /**\n * A function to extract elements from a page.\n */\n toElements?: (page: TPage) => TElement[];\n}\n\n/**\n * Options for the paging helper\n */\nexport interface BuildPagedAsyncIteratorOptions {\n itemName?: string;\n nextLinkName?: string;\n nextLinkMethod?: \"GET\" | \"POST\";\n apiVersion?: string;\n}\n\n/**\n * Helper to paginate results in a generic way and return a PagedAsyncIterableIterator\n */\nexport function buildPagedAsyncIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n TResponse extends PathUncheckedResponse = PathUncheckedResponse,\n>(\n client: Client,\n getInitialResponse: () => PromiseLike<TResponse>,\n processResponseBody: (result: TResponse) => PromiseLike<unknown>,\n expectedStatuses: string[],\n options: BuildPagedAsyncIteratorOptions = {},\n): PagedAsyncIterableIterator<TElement, TPage, TPageSettings> {\n const itemName = options.itemName ?? \"value\";\n const nextLinkName = options.nextLinkName ?? \"nextLink\";\n const nextLinkMethod = options.nextLinkMethod ?? \"GET\";\n const apiVersion = options.apiVersion;\n const pagedResult: PagedResult<TElement, TPage, TPageSettings> = {\n getPage: async (pageLink?: string) => {\n let result;\n if (pageLink === undefined) {\n result = await getInitialResponse();\n } else {\n const resolvedPageLink = apiVersion ? addApiVersionToUrl(pageLink, apiVersion) : pageLink;\n result =\n nextLinkMethod === \"POST\"\n ? await client.pathUnchecked(resolvedPageLink).post()\n : await client.pathUnchecked(resolvedPageLink).get();\n }\n checkPagingRequest(result, expectedStatuses);\n const results = await processResponseBody(result as TResponse);\n const nextLink = getNextLink(results, nextLinkName);\n const values = getElements<TElement>(results, itemName) as TPage;\n return {\n page: values,\n nextPageLink: nextLink,\n };\n },\n byPage: (settings?: TPageSettings) => {\n const { continuationToken } = settings ?? {};\n return getPageAsyncIterator(pagedResult, {\n pageLink: continuationToken,\n });\n },\n };\n return getPagedAsyncIterator(pagedResult);\n}\n\n/**\n * returns an async iterator that iterates over results. It also has a `byPage`\n * method that returns pages of items at once.\n *\n * @param pagedResult - an object that specifies how to get pages.\n * @returns a paged async iterator that iterates over results.\n */\n\nfunction getPagedAsyncIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n): PagedAsyncIterableIterator<TElement, TPage, TPageSettings> {\n const iter = getItemAsyncIterator<TElement, TPage, TPageSettings>(pagedResult);\n return {\n next() {\n return iter.next();\n },\n [Symbol.asyncIterator]() {\n return this;\n },\n byPage:\n pagedResult?.byPage ??\n ((settings?: TPageSettings) => {\n const { continuationToken } = settings ?? {};\n return getPageAsyncIterator(pagedResult, {\n pageLink: continuationToken,\n });\n }),\n };\n}\n\nasync function* getItemAsyncIterator<TElement, TPage, TPageSettings extends PageSettings>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n): AsyncIterableIterator<TElement> {\n const pages = getPageAsyncIterator(pagedResult);\n for await (const page of pages) {\n yield* page as unknown as TElement[];\n }\n}\n\nasync function* getPageAsyncIterator<TElement, TPage, TPageSettings extends PageSettings>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n options: {\n pageLink?: string;\n } = {},\n): AsyncIterableIterator<ContinuablePage<TElement, TPage>> {\n const { pageLink } = options;\n let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);\n if (!response) {\n return;\n }\n let result = response.page as ContinuablePage<TElement, TPage>;\n result.continuationToken = response.nextPageLink;\n yield result;\n while (response.nextPageLink) {\n response = await pagedResult.getPage(response.nextPageLink);\n if (!response) {\n return;\n }\n result = response.page as ContinuablePage<TElement, TPage>;\n result.continuationToken = response.nextPageLink;\n yield result;\n }\n}\n\n/**\n * Gets for the value of nextLink in the body\n */\nfunction getNextLink(body: unknown, nextLinkName?: string): string | undefined {\n if (!nextLinkName) {\n return undefined;\n }\n\n const nextLink = (body as Record<string, unknown>)[nextLinkName];\n\n if (typeof nextLink !== \"string\" && typeof nextLink !== \"undefined\" && nextLink !== null) {\n throw new RestError(\n `Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`,\n );\n }\n\n if (nextLink === null) {\n return undefined;\n }\n\n return nextLink;\n}\n\n/**\n * Gets the elements of the current request in the body.\n */\nfunction getElements<T = unknown>(body: unknown, itemName: string): T[] {\n const value = (body as Record<string, unknown>)[itemName] as T[];\n if (!Array.isArray(value)) {\n throw new RestError(\n `Couldn't paginate response\\n Body doesn't contain an array property with name: ${itemName}`,\n );\n }\n\n return value ?? [];\n}\n\n/**\n * Checks if a request failed\n */\nfunction checkPagingRequest(response: PathUncheckedResponse, expectedStatuses: string[]): void {\n if (!expectedStatuses.includes(response.status)) {\n throw createRestError(\n `Pagination failed with unexpected statusCode ${response.status}`,\n response,\n );\n }\n}\n\n/**\n * Adds the api-version query parameter on a URL if it's not present.\n * @param url - the URL to modify\n * @param apiVersion - the API version to set\n * @returns - the URL with the api-version query parameter set\n */\nfunction addApiVersionToUrl(url: string, apiVersion: string): string {\n // The base URL is only used for parsing and won't appear in the returned URL\n const urlObj = new URL(url, \"https://microsoft.com\");\n if (!urlObj.searchParams.get(\"api-version\")) {\n // Append one if there is no apiVersion\n return `${url}${\n Array.from(urlObj.searchParams.keys()).length > 0 ? \"&\" : \"?\"\n }api-version=${apiVersion}`;\n }\n return url;\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -25,6 +25,10 @@ export interface GetLongRunningPollerOptions<TResponse> {
25
25
  * The function to get the initial response
26
26
  */
27
27
  getInitialResponse?: () => PromiseLike<TResponse>;
28
+ /**
29
+ * The api-version of the LRO
30
+ */
31
+ apiVersion?: string;
28
32
  }
29
33
  export declare function getLongRunningPoller<TResponse extends PathUncheckedResponse, TResult = void>(client: Client, processResponseBody: (result: TResponse) => Promise<TResult>, expectedStatuses: string[], options: GetLongRunningPollerOptions<TResponse>): PollerLike<OperationState<TResult>, TResult>;
30
34
  //# sourceMappingURL=pollingHelpers.d.ts.map
@@ -1,82 +1,101 @@
1
- "use strict";
2
- // Copyright (c) Microsoft Corporation.
3
- // Licensed under the MIT License.
4
- Object.defineProperty(exports, "__esModule", { value: true });
5
- exports.getLongRunningPoller = getLongRunningPoller;
6
- const core_lro_1 = require("@azure/core-lro");
7
- const core_client_1 = require("@azure-rest/core-client");
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var pollingHelpers_exports = {};
19
+ __export(pollingHelpers_exports, {
20
+ getLongRunningPoller: () => getLongRunningPoller
21
+ });
22
+ module.exports = __toCommonJS(pollingHelpers_exports);
23
+ var import_core_lro = require("@azure/core-lro");
24
+ var import_core_client = require("@azure-rest/core-client");
8
25
  function getLongRunningPoller(client, processResponseBody, expectedStatuses, options) {
9
- const { restoreFrom, getInitialResponse } = options;
10
- if (!restoreFrom && !getInitialResponse) {
11
- throw new Error("Either restoreFrom or getInitialResponse must be specified");
26
+ const { restoreFrom, getInitialResponse, apiVersion } = options;
27
+ if (!restoreFrom && !getInitialResponse) {
28
+ throw new Error("Either restoreFrom or getInitialResponse must be specified");
29
+ }
30
+ let initialResponse = void 0;
31
+ const pollAbortController = new AbortController();
32
+ const poller = {
33
+ sendInitialRequest: async () => {
34
+ if (!getInitialResponse) {
35
+ throw new Error("getInitialResponse is required when initializing a new poller");
36
+ }
37
+ initialResponse = await getInitialResponse();
38
+ return getLroResponse(initialResponse, expectedStatuses);
39
+ },
40
+ sendPollRequest: async (path, pollOptions) => {
41
+ function abortListener() {
42
+ pollAbortController.abort();
43
+ }
44
+ const abortSignal = pollAbortController.signal;
45
+ if (options.abortSignal?.aborted) {
46
+ pollAbortController.abort();
47
+ } else if (pollOptions?.abortSignal?.aborted) {
48
+ pollAbortController.abort();
49
+ } else if (!abortSignal.aborted) {
50
+ options.abortSignal?.addEventListener("abort", abortListener, {
51
+ once: true
52
+ });
53
+ pollOptions?.abortSignal?.addEventListener("abort", abortListener, {
54
+ once: true
55
+ });
56
+ }
57
+ let response;
58
+ try {
59
+ const pollingPath = apiVersion ? addApiVersionToUrl(path, apiVersion) : path;
60
+ response = await client.pathUnchecked(pollingPath).get({ abortSignal });
61
+ } finally {
62
+ options.abortSignal?.removeEventListener("abort", abortListener);
63
+ pollOptions?.abortSignal?.removeEventListener("abort", abortListener);
64
+ }
65
+ return getLroResponse(response, expectedStatuses);
12
66
  }
13
- let initialResponse = undefined;
14
- const pollAbortController = new AbortController();
15
- const poller = {
16
- sendInitialRequest: async () => {
17
- if (!getInitialResponse) {
18
- throw new Error("getInitialResponse is required when initializing a new poller");
19
- }
20
- initialResponse = await getInitialResponse();
21
- return getLroResponse(initialResponse, expectedStatuses);
22
- },
23
- sendPollRequest: async (path, pollOptions) => {
24
- // The poll request would both listen to the user provided abort signal and the poller's own abort signal
25
- function abortListener() {
26
- pollAbortController.abort();
27
- }
28
- const abortSignal = pollAbortController.signal;
29
- if (options.abortSignal?.aborted) {
30
- pollAbortController.abort();
31
- }
32
- else if (pollOptions?.abortSignal?.aborted) {
33
- pollAbortController.abort();
34
- }
35
- else if (!abortSignal.aborted) {
36
- options.abortSignal?.addEventListener("abort", abortListener, {
37
- once: true,
38
- });
39
- pollOptions?.abortSignal?.addEventListener("abort", abortListener, {
40
- once: true,
41
- });
42
- }
43
- let response;
44
- try {
45
- response = await client.pathUnchecked(path).get({ abortSignal });
46
- }
47
- finally {
48
- options.abortSignal?.removeEventListener("abort", abortListener);
49
- pollOptions?.abortSignal?.removeEventListener("abort", abortListener);
50
- }
51
- return getLroResponse(response, expectedStatuses);
52
- },
53
- };
54
- return (0, core_lro_1.createHttpPoller)(poller, {
55
- intervalInMs: options?.updateIntervalInMs,
56
- resourceLocationConfig: options?.resourceLocationConfig,
57
- restoreFrom: options?.restoreFrom,
58
- processResult: (result) => {
59
- return processResponseBody(result);
60
- },
61
- });
67
+ };
68
+ return (0, import_core_lro.createHttpPoller)(poller, {
69
+ intervalInMs: options?.updateIntervalInMs,
70
+ resourceLocationConfig: options?.resourceLocationConfig,
71
+ restoreFrom: options?.restoreFrom,
72
+ processResult: (result) => {
73
+ return processResponseBody(result);
74
+ }
75
+ });
62
76
  }
63
- /**
64
- * Converts a Rest Client response to a response that the LRO implementation understands
65
- * @param response - a rest client http response
66
- * @param deserializeFn - deserialize function to convert Rest response to modular output
67
- * @returns - An LRO response that the LRO implementation understands
68
- */
69
77
  function getLroResponse(response, expectedStatuses) {
70
- if (!expectedStatuses.includes(response.status)) {
71
- throw (0, core_client_1.createRestError)(response);
78
+ if (!expectedStatuses.includes(response.status)) {
79
+ throw (0, import_core_client.createRestError)(response);
80
+ }
81
+ return {
82
+ flatResponse: response,
83
+ rawResponse: {
84
+ ...response,
85
+ statusCode: Number.parseInt(response.status),
86
+ body: response.body
72
87
  }
73
- return {
74
- flatResponse: response,
75
- rawResponse: {
76
- ...response,
77
- statusCode: Number.parseInt(response.status),
78
- body: response.body,
79
- },
80
- };
88
+ };
89
+ }
90
+ function addApiVersionToUrl(url, apiVersion) {
91
+ const urlObj = new URL(url, "https://microsoft.com");
92
+ if (!urlObj.searchParams.get("api-version")) {
93
+ return `${url}${Array.from(urlObj.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
94
+ }
95
+ return url;
81
96
  }
82
- //# sourceMappingURL=pollingHelpers.js.map
97
+ // Annotate the CommonJS export names for ESM import in node:
98
+ 0 && (module.exports = {
99
+ getLongRunningPoller
100
+ });
101
+ //# sourceMappingURL=pollingHelpers.js.map