@azure/ai-projects 2.0.1 → 2.0.2

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 (291) hide show
  1. package/README.md +5 -5
  2. package/dist/browser/api/datasets/operations.d.ts.map +1 -1
  3. package/dist/browser/api/datasets/operations.js +9 -8
  4. package/dist/browser/api/datasets/operations.js.map +1 -1
  5. package/dist/browser/constants.d.ts +1 -1
  6. package/dist/browser/constants.js +1 -1
  7. package/dist/browser/constants.js.map +1 -1
  8. package/dist/commonjs/aiProjectClient.js +1 -0
  9. package/dist/commonjs/aiProjectClient.js.map +1 -1
  10. package/dist/commonjs/api/agents/index.js +1 -0
  11. package/dist/commonjs/api/agents/index.js.map +1 -1
  12. package/dist/commonjs/api/agents/operations.js +1 -0
  13. package/dist/commonjs/api/agents/operations.js.map +1 -1
  14. package/dist/commonjs/api/agents/options.js +1 -0
  15. package/dist/commonjs/api/agents/options.js.map +1 -1
  16. package/dist/commonjs/api/aiProjectContext.js +1 -0
  17. package/dist/commonjs/api/aiProjectContext.js.map +1 -1
  18. package/dist/commonjs/api/beta/evaluationTaxonomies/index.js +1 -0
  19. package/dist/commonjs/api/beta/evaluationTaxonomies/index.js.map +1 -1
  20. package/dist/commonjs/api/beta/evaluationTaxonomies/operations.js +1 -0
  21. package/dist/commonjs/api/beta/evaluationTaxonomies/operations.js.map +1 -1
  22. package/dist/commonjs/api/beta/evaluationTaxonomies/options.js +1 -0
  23. package/dist/commonjs/api/beta/evaluationTaxonomies/options.js.map +1 -1
  24. package/dist/commonjs/api/beta/evaluators/index.js +1 -0
  25. package/dist/commonjs/api/beta/evaluators/index.js.map +1 -1
  26. package/dist/commonjs/api/beta/evaluators/operations.js +1 -0
  27. package/dist/commonjs/api/beta/evaluators/operations.js.map +1 -1
  28. package/dist/commonjs/api/beta/evaluators/options.js +1 -0
  29. package/dist/commonjs/api/beta/evaluators/options.js.map +1 -1
  30. package/dist/commonjs/api/beta/insights/index.js +1 -0
  31. package/dist/commonjs/api/beta/insights/index.js.map +1 -1
  32. package/dist/commonjs/api/beta/insights/operations.js +1 -0
  33. package/dist/commonjs/api/beta/insights/operations.js.map +1 -1
  34. package/dist/commonjs/api/beta/insights/options.js +1 -0
  35. package/dist/commonjs/api/beta/insights/options.js.map +1 -1
  36. package/dist/commonjs/api/beta/memoryStores/index.js +1 -0
  37. package/dist/commonjs/api/beta/memoryStores/index.js.map +1 -1
  38. package/dist/commonjs/api/beta/memoryStores/operations.js +1 -0
  39. package/dist/commonjs/api/beta/memoryStores/operations.js.map +1 -1
  40. package/dist/commonjs/api/beta/memoryStores/options.js +1 -0
  41. package/dist/commonjs/api/beta/memoryStores/options.js.map +1 -1
  42. package/dist/commonjs/api/beta/redTeams/index.js +1 -0
  43. package/dist/commonjs/api/beta/redTeams/index.js.map +1 -1
  44. package/dist/commonjs/api/beta/redTeams/operations.js +1 -0
  45. package/dist/commonjs/api/beta/redTeams/operations.js.map +1 -1
  46. package/dist/commonjs/api/beta/redTeams/options.js +1 -0
  47. package/dist/commonjs/api/beta/redTeams/options.js.map +1 -1
  48. package/dist/commonjs/api/beta/schedules/index.js +1 -0
  49. package/dist/commonjs/api/beta/schedules/index.js.map +1 -1
  50. package/dist/commonjs/api/beta/schedules/operations.js +1 -0
  51. package/dist/commonjs/api/beta/schedules/operations.js.map +1 -1
  52. package/dist/commonjs/api/beta/schedules/options.js +1 -0
  53. package/dist/commonjs/api/beta/schedules/options.js.map +1 -1
  54. package/dist/commonjs/api/connections/index.js +1 -0
  55. package/dist/commonjs/api/connections/index.js.map +1 -1
  56. package/dist/commonjs/api/connections/operations.js +1 -0
  57. package/dist/commonjs/api/connections/operations.js.map +1 -1
  58. package/dist/commonjs/api/connections/options.js +1 -0
  59. package/dist/commonjs/api/connections/options.js.map +1 -1
  60. package/dist/commonjs/api/datasets/index.js +1 -0
  61. package/dist/commonjs/api/datasets/index.js.map +1 -1
  62. package/dist/commonjs/api/datasets/operations.d.ts.map +1 -1
  63. package/dist/commonjs/api/datasets/operations.js +10 -8
  64. package/dist/commonjs/api/datasets/operations.js.map +3 -3
  65. package/dist/commonjs/api/datasets/options.js +1 -0
  66. package/dist/commonjs/api/datasets/options.js.map +1 -1
  67. package/dist/commonjs/api/deployments/index.js +1 -0
  68. package/dist/commonjs/api/deployments/index.js.map +1 -1
  69. package/dist/commonjs/api/deployments/operations.js +1 -0
  70. package/dist/commonjs/api/deployments/operations.js.map +1 -1
  71. package/dist/commonjs/api/deployments/options.js +1 -0
  72. package/dist/commonjs/api/deployments/options.js.map +1 -1
  73. package/dist/commonjs/api/evaluationRules/index.js +1 -0
  74. package/dist/commonjs/api/evaluationRules/index.js.map +1 -1
  75. package/dist/commonjs/api/evaluationRules/operations.js +1 -0
  76. package/dist/commonjs/api/evaluationRules/operations.js.map +1 -1
  77. package/dist/commonjs/api/evaluationRules/options.js +1 -0
  78. package/dist/commonjs/api/evaluationRules/options.js.map +1 -1
  79. package/dist/commonjs/api/index.js +1 -0
  80. package/dist/commonjs/api/index.js.map +1 -1
  81. package/dist/commonjs/api/indexes/index.js +1 -0
  82. package/dist/commonjs/api/indexes/index.js.map +1 -1
  83. package/dist/commonjs/api/indexes/operations.js +1 -0
  84. package/dist/commonjs/api/indexes/operations.js.map +1 -1
  85. package/dist/commonjs/api/indexes/options.js +1 -0
  86. package/dist/commonjs/api/indexes/options.js.map +1 -1
  87. package/dist/commonjs/api/telemetry/index.js +1 -0
  88. package/dist/commonjs/api/telemetry/index.js.map +1 -1
  89. package/dist/commonjs/api/telemetry/operations.js +1 -0
  90. package/dist/commonjs/api/telemetry/operations.js.map +1 -1
  91. package/dist/commonjs/classic/agents/index.js +1 -0
  92. package/dist/commonjs/classic/agents/index.js.map +1 -1
  93. package/dist/commonjs/classic/beta/evaluationTaxonomies/index.js +1 -0
  94. package/dist/commonjs/classic/beta/evaluationTaxonomies/index.js.map +1 -1
  95. package/dist/commonjs/classic/beta/evaluators/index.js +1 -0
  96. package/dist/commonjs/classic/beta/evaluators/index.js.map +1 -1
  97. package/dist/commonjs/classic/beta/index.js +1 -0
  98. package/dist/commonjs/classic/beta/index.js.map +1 -1
  99. package/dist/commonjs/classic/beta/insights/index.js +1 -0
  100. package/dist/commonjs/classic/beta/insights/index.js.map +1 -1
  101. package/dist/commonjs/classic/beta/memoryStores/index.js +1 -0
  102. package/dist/commonjs/classic/beta/memoryStores/index.js.map +1 -1
  103. package/dist/commonjs/classic/beta/redTeams/index.js +1 -0
  104. package/dist/commonjs/classic/beta/redTeams/index.js.map +1 -1
  105. package/dist/commonjs/classic/beta/schedules/index.js +1 -0
  106. package/dist/commonjs/classic/beta/schedules/index.js.map +1 -1
  107. package/dist/commonjs/classic/connections/index.js +1 -0
  108. package/dist/commonjs/classic/connections/index.js.map +1 -1
  109. package/dist/commonjs/classic/datasets/index.js +1 -0
  110. package/dist/commonjs/classic/datasets/index.js.map +1 -1
  111. package/dist/commonjs/classic/deployments/index.js +1 -0
  112. package/dist/commonjs/classic/deployments/index.js.map +1 -1
  113. package/dist/commonjs/classic/evaluationRules/index.js +1 -0
  114. package/dist/commonjs/classic/evaluationRules/index.js.map +1 -1
  115. package/dist/commonjs/classic/index.js +1 -0
  116. package/dist/commonjs/classic/index.js.map +1 -1
  117. package/dist/commonjs/classic/indexes/index.js +1 -0
  118. package/dist/commonjs/classic/indexes/index.js.map +1 -1
  119. package/dist/commonjs/classic/telemetry/index.js +1 -0
  120. package/dist/commonjs/classic/telemetry/index.js.map +1 -1
  121. package/dist/commonjs/constants.d.ts +1 -1
  122. package/dist/commonjs/constants.js +2 -1
  123. package/dist/commonjs/constants.js.map +2 -2
  124. package/dist/commonjs/getCustomFetch.js +1 -0
  125. package/dist/commonjs/getCustomFetch.js.map +1 -1
  126. package/dist/commonjs/index.js +1 -0
  127. package/dist/commonjs/index.js.map +1 -1
  128. package/dist/commonjs/logger.js +1 -0
  129. package/dist/commonjs/logger.js.map +1 -1
  130. package/dist/commonjs/models/index.js +1 -0
  131. package/dist/commonjs/models/index.js.map +1 -1
  132. package/dist/commonjs/models/models.js +1 -0
  133. package/dist/commonjs/models/models.js.map +1 -1
  134. package/dist/commonjs/overwriteOpenAIClient.js +1 -0
  135. package/dist/commonjs/overwriteOpenAIClient.js.map +1 -1
  136. package/dist/commonjs/static-helpers/pagingHelpers.js +1 -0
  137. package/dist/commonjs/static-helpers/pagingHelpers.js.map +1 -1
  138. package/dist/commonjs/static-helpers/pollingHelpers.js +1 -0
  139. package/dist/commonjs/static-helpers/pollingHelpers.js.map +1 -1
  140. package/dist/commonjs/static-helpers/serialization/serialize-record.js +1 -0
  141. package/dist/commonjs/static-helpers/serialization/serialize-record.js.map +1 -1
  142. package/dist/commonjs/static-helpers/urlTemplate.js +1 -0
  143. package/dist/commonjs/static-helpers/urlTemplate.js.map +1 -1
  144. package/dist/commonjs/tsdoc-metadata.json +1 -1
  145. package/dist/commonjs/util.js +1 -0
  146. package/dist/commonjs/util.js.map +1 -1
  147. package/dist/esm/aiProjectClient.js +119 -94
  148. package/dist/esm/aiProjectClient.js.map +1 -7
  149. package/dist/esm/api/agents/index.js +4 -28
  150. package/dist/esm/api/agents/index.js.map +1 -7
  151. package/dist/esm/api/agents/operations.js +375 -473
  152. package/dist/esm/api/agents/operations.js.map +1 -7
  153. package/dist/esm/api/agents/options.js +4 -0
  154. package/dist/esm/api/agents/options.js.map +1 -7
  155. package/dist/esm/api/aiProjectContext.js +21 -19
  156. package/dist/esm/api/aiProjectContext.js.map +1 -7
  157. package/dist/esm/api/beta/evaluationTaxonomies/index.js +4 -8
  158. package/dist/esm/api/beta/evaluationTaxonomies/index.js.map +1 -7
  159. package/dist/esm/api/beta/evaluationTaxonomies/operations.js +150 -183
  160. package/dist/esm/api/beta/evaluationTaxonomies/operations.js.map +1 -7
  161. package/dist/esm/api/beta/evaluationTaxonomies/options.js +4 -0
  162. package/dist/esm/api/beta/evaluationTaxonomies/options.js.map +1 -7
  163. package/dist/esm/api/beta/evaluators/index.js +4 -16
  164. package/dist/esm/api/beta/evaluators/index.js.map +1 -7
  165. package/dist/esm/api/beta/evaluators/operations.js +192 -243
  166. package/dist/esm/api/beta/evaluators/operations.js.map +1 -7
  167. package/dist/esm/api/beta/evaluators/options.js +4 -0
  168. package/dist/esm/api/beta/evaluators/options.js.map +1 -7
  169. package/dist/esm/api/beta/insights/index.js +4 -6
  170. package/dist/esm/api/beta/insights/index.js.map +1 -7
  171. package/dist/esm/api/beta/insights/operations.js +109 -126
  172. package/dist/esm/api/beta/insights/operations.js.map +1 -7
  173. package/dist/esm/api/beta/insights/options.js +4 -0
  174. package/dist/esm/api/beta/insights/options.js.map +1 -7
  175. package/dist/esm/api/beta/memoryStores/index.js +4 -22
  176. package/dist/esm/api/beta/memoryStores/index.js.map +1 -7
  177. package/dist/esm/api/beta/memoryStores/operations.js +305 -374
  178. package/dist/esm/api/beta/memoryStores/operations.js.map +1 -7
  179. package/dist/esm/api/beta/memoryStores/options.js +4 -0
  180. package/dist/esm/api/beta/memoryStores/options.js.map +1 -7
  181. package/dist/esm/api/beta/redTeams/index.js +4 -6
  182. package/dist/esm/api/beta/redTeams/index.js.map +1 -7
  183. package/dist/esm/api/beta/redTeams/operations.js +95 -119
  184. package/dist/esm/api/beta/redTeams/operations.js.map +1 -7
  185. package/dist/esm/api/beta/redTeams/options.js +4 -0
  186. package/dist/esm/api/beta/redTeams/options.js.map +1 -7
  187. package/dist/esm/api/beta/schedules/index.js +4 -9
  188. package/dist/esm/api/beta/schedules/index.js.map +1 -7
  189. package/dist/esm/api/beta/schedules/operations.js +204 -248
  190. package/dist/esm/api/beta/schedules/operations.js.map +1 -7
  191. package/dist/esm/api/beta/schedules/options.js +4 -0
  192. package/dist/esm/api/beta/schedules/options.js.map +1 -7
  193. package/dist/esm/api/connections/index.js +4 -6
  194. package/dist/esm/api/connections/index.js.map +1 -7
  195. package/dist/esm/api/connections/operations.js +109 -116
  196. package/dist/esm/api/connections/operations.js.map +1 -7
  197. package/dist/esm/api/connections/options.js +4 -0
  198. package/dist/esm/api/connections/options.js.map +1 -7
  199. package/dist/esm/api/datasets/index.js +4 -18
  200. package/dist/esm/api/datasets/index.js.map +1 -7
  201. package/dist/esm/api/datasets/operations.d.ts.map +1 -1
  202. package/dist/esm/api/datasets/operations.js +288 -355
  203. package/dist/esm/api/datasets/operations.js.map +1 -7
  204. package/dist/esm/api/datasets/options.js +4 -0
  205. package/dist/esm/api/datasets/options.js.map +1 -7
  206. package/dist/esm/api/deployments/index.js +4 -5
  207. package/dist/esm/api/deployments/index.js.map +1 -7
  208. package/dist/esm/api/deployments/operations.js +57 -70
  209. package/dist/esm/api/deployments/operations.js.map +1 -7
  210. package/dist/esm/api/deployments/options.js +4 -0
  211. package/dist/esm/api/deployments/options.js.map +1 -7
  212. package/dist/esm/api/evaluationRules/index.js +4 -7
  213. package/dist/esm/api/evaluationRules/index.js.map +1 -7
  214. package/dist/esm/api/evaluationRules/operations.js +121 -144
  215. package/dist/esm/api/evaluationRules/operations.js.map +1 -7
  216. package/dist/esm/api/evaluationRules/options.js +4 -0
  217. package/dist/esm/api/evaluationRules/options.js.map +1 -7
  218. package/dist/esm/api/index.js +4 -4
  219. package/dist/esm/api/index.js.map +1 -7
  220. package/dist/esm/api/indexes/index.js +4 -8
  221. package/dist/esm/api/indexes/index.js.map +1 -7
  222. package/dist/esm/api/indexes/operations.js +116 -161
  223. package/dist/esm/api/indexes/operations.js.map +1 -7
  224. package/dist/esm/api/indexes/options.js +4 -0
  225. package/dist/esm/api/indexes/options.js.map +1 -7
  226. package/dist/esm/api/telemetry/index.js +4 -4
  227. package/dist/esm/api/telemetry/index.js.map +1 -7
  228. package/dist/esm/api/telemetry/operations.js +53 -46
  229. package/dist/esm/api/telemetry/operations.js.map +1 -7
  230. package/dist/esm/classic/agents/index.js +40 -80
  231. package/dist/esm/classic/agents/index.js.map +1 -7
  232. package/dist/esm/classic/beta/evaluationTaxonomies/index.js +15 -21
  233. package/dist/esm/classic/beta/evaluationTaxonomies/index.js.map +1 -7
  234. package/dist/esm/classic/beta/evaluators/index.js +16 -23
  235. package/dist/esm/classic/beta/evaluators/index.js.map +1 -7
  236. package/dist/esm/classic/beta/index.js +18 -18
  237. package/dist/esm/classic/beta/index.js.map +1 -7
  238. package/dist/esm/classic/beta/insights/index.js +12 -12
  239. package/dist/esm/classic/beta/insights/index.js.map +1 -7
  240. package/dist/esm/classic/beta/memoryStores/index.js +19 -29
  241. package/dist/esm/classic/beta/memoryStores/index.js.map +1 -7
  242. package/dist/esm/classic/beta/redTeams/index.js +12 -12
  243. package/dist/esm/classic/beta/redTeams/index.js.map +1 -7
  244. package/dist/esm/classic/beta/schedules/index.js +16 -23
  245. package/dist/esm/classic/beta/schedules/index.js.map +1 -7
  246. package/dist/esm/classic/connections/index.js +13 -13
  247. package/dist/esm/classic/connections/index.js.map +1 -7
  248. package/dist/esm/classic/datasets/index.js +19 -29
  249. package/dist/esm/classic/datasets/index.js.map +1 -7
  250. package/dist/esm/classic/deployments/index.js +11 -11
  251. package/dist/esm/classic/deployments/index.js.map +1 -7
  252. package/dist/esm/classic/evaluationRules/index.js +13 -13
  253. package/dist/esm/classic/evaluationRules/index.js.map +1 -7
  254. package/dist/esm/classic/index.js +4 -0
  255. package/dist/esm/classic/index.js.map +1 -7
  256. package/dist/esm/classic/indexes/index.js +14 -14
  257. package/dist/esm/classic/indexes/index.js.map +1 -7
  258. package/dist/esm/classic/telemetry/index.js +7 -9
  259. package/dist/esm/classic/telemetry/index.js.map +1 -7
  260. package/dist/esm/constants.d.ts +1 -1
  261. package/dist/esm/constants.js +11 -6
  262. package/dist/esm/constants.js.map +1 -7
  263. package/dist/esm/getCustomFetch.js +40 -33
  264. package/dist/esm/getCustomFetch.js.map +1 -7
  265. package/dist/esm/index.js +4 -4
  266. package/dist/esm/index.js.map +1 -7
  267. package/dist/esm/logger.js +4 -4
  268. package/dist/esm/logger.js.map +1 -7
  269. package/dist/esm/models/index.js +4 -0
  270. package/dist/esm/models/index.js.map +1 -7
  271. package/dist/esm/models/models.js +3709 -4160
  272. package/dist/esm/models/models.js.map +1 -7
  273. package/dist/esm/overwriteOpenAIClient.js +13 -13
  274. package/dist/esm/overwriteOpenAIClient.js.map +1 -7
  275. package/dist/esm/static-helpers/pagingHelpers.js +123 -99
  276. package/dist/esm/static-helpers/pagingHelpers.js.map +1 -7
  277. package/dist/esm/static-helpers/pollingHelpers.js +98 -75
  278. package/dist/esm/static-helpers/pollingHelpers.js.map +1 -7
  279. package/dist/esm/static-helpers/serialization/serialize-record.js +18 -16
  280. package/dist/esm/static-helpers/serialization/serialize-record.js.map +1 -7
  281. package/dist/esm/static-helpers/urlTemplate.js +169 -142
  282. package/dist/esm/static-helpers/urlTemplate.js.map +1 -7
  283. package/dist/esm/util.js +84 -63
  284. package/dist/esm/util.js.map +1 -7
  285. package/dist/react-native/api/datasets/operations.d.ts.map +1 -1
  286. package/dist/react-native/api/datasets/operations.js +9 -8
  287. package/dist/react-native/api/datasets/operations.js.map +1 -1
  288. package/dist/react-native/constants.d.ts +1 -1
  289. package/dist/react-native/constants.js +1 -1
  290. package/dist/react-native/constants.js.map +1 -1
  291. package/package.json +9 -9
@@ -1,14 +1,14 @@
1
- function overwriteOpenAIClient(openaiClient) {
2
- const responsesCreate = openaiClient.responses.create.bind(openaiClient.responses);
3
- openaiClient.responses.create = ((...args) => {
4
- const [body, options = {}] = args;
5
- const nextBody = { ...body, ...options.body || {} };
6
- const { body: _, ...nextOptions } = options;
7
- const response = responsesCreate(nextBody, nextOptions);
8
- return response;
9
- });
10
- return openaiClient;
1
+ // Copyright (c) Microsoft Corporation.
2
+ // Licensed under the MIT License.
3
+ export function overwriteOpenAIClient(openaiClient) {
4
+ const responsesCreate = openaiClient.responses.create.bind(openaiClient.responses);
5
+ openaiClient.responses.create = ((...args) => {
6
+ const [body, options = {}] = args;
7
+ const nextBody = { ...body, ...(options.body || {}) };
8
+ const { body: _, ...nextOptions } = options;
9
+ const response = responsesCreate(nextBody, nextOptions);
10
+ return response;
11
+ });
12
+ return openaiClient;
11
13
  }
12
- export {
13
- overwriteOpenAIClient
14
- };
14
+ //# sourceMappingURL=overwriteOpenAIClient.js.map
@@ -1,7 +1 @@
1
- {
2
- "version": 3,
3
- "sources": ["/mnt/vss/_work/1/s/sdk/ai/ai-projects/src/overwriteOpenAIClient.ts"],
4
- "sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type OpenAI from \"openai\";\n\nexport function overwriteOpenAIClient(openaiClient: OpenAI): OpenAI {\n const responsesCreate = openaiClient.responses.create.bind(openaiClient.responses);\n openaiClient.responses.create = ((...args: Parameters<typeof responsesCreate>) => {\n const [body, options = {}] = args;\n const nextBody = { ...body, ...(options.body || {}) };\n const { body: _, ...nextOptions } = options;\n const response = responsesCreate(nextBody, nextOptions);\n return response;\n }) as typeof responsesCreate;\n return openaiClient;\n}\n"],
5
- "mappings": "AAKO,SAAS,sBAAsB,cAA8B;AAClE,QAAM,kBAAkB,aAAa,UAAU,OAAO,KAAK,aAAa,SAAS;AACjF,eAAa,UAAU,UAAU,IAAI,SAA6C;AAChF,UAAM,CAAC,MAAM,UAAU,CAAC,CAAC,IAAI;AAC7B,UAAM,WAAW,EAAE,GAAG,MAAM,GAAI,QAAQ,QAAQ,CAAC,EAAG;AACpD,UAAM,EAAE,MAAM,GAAG,GAAG,YAAY,IAAI;AACpC,UAAM,WAAW,gBAAgB,UAAU,WAAW;AACtD,WAAO;AAAA,EACT;AACA,SAAO;AACT;",
6
- "names": []
7
- }
1
+ {"version":3,"file":"overwriteOpenAIClient.js","sourceRoot":"","sources":["../../src/overwriteOpenAIClient.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAIlC,MAAM,UAAU,qBAAqB,CAAC,YAAoB;IACxD,MAAM,eAAe,GAAG,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IACnF,YAAY,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,IAAwC,EAAE,EAAE;QAC/E,MAAM,CAAC,IAAI,EAAE,OAAO,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC;QAClC,MAAM,QAAQ,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC,EAAE,CAAC;QACtD,MAAM,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,WAAW,EAAE,GAAG,OAAO,CAAC;QAC5C,MAAM,QAAQ,GAAG,eAAe,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;QACxD,OAAO,QAAQ,CAAC;IAClB,CAAC,CAA2B,CAAC;IAC7B,OAAO,YAAY,CAAC;AACtB,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type OpenAI from \"openai\";\n\nexport function overwriteOpenAIClient(openaiClient: OpenAI): OpenAI {\n const responsesCreate = openaiClient.responses.create.bind(openaiClient.responses);\n openaiClient.responses.create = ((...args: Parameters<typeof responsesCreate>) => {\n const [body, options = {}] = args;\n const nextBody = { ...body, ...(options.body || {}) };\n const { body: _, ...nextOptions } = options;\n const response = responsesCreate(nextBody, nextOptions);\n return response;\n }) as typeof responsesCreate;\n return openaiClient;\n}\n"]}
@@ -1,120 +1,144 @@
1
+ // Copyright (c) Microsoft Corporation.
2
+ // Licensed under the MIT License.
1
3
  import { createRestError } from "@azure-rest/core-client";
2
4
  import { RestError } from "@azure/core-rest-pipeline";
3
- function buildPagedAsyncIterator(client, getInitialResponse, processResponseBody, expectedStatuses, options = {}) {
4
- const itemName = options.itemName ?? "value";
5
- const nextLinkName = options.nextLinkName ?? "nextLink";
6
- const nextLinkMethod = options.nextLinkMethod ?? "GET";
7
- const apiVersion = options.apiVersion;
8
- const nextPageRequestOptions = options.nextPageRequestOptions;
9
- const pagedResult = {
10
- getPage: async (pageLink) => {
11
- let result;
12
- if (pageLink === void 0) {
13
- result = await getInitialResponse();
14
- } else {
15
- const resolvedPageLink = apiVersion ? addApiVersionToUrl(pageLink, apiVersion) : pageLink;
16
- result = nextLinkMethod === "POST" ? await client.pathUnchecked(resolvedPageLink).post(nextPageRequestOptions) : await client.pathUnchecked(resolvedPageLink).get(nextPageRequestOptions);
17
- }
18
- checkPagingRequest(result, expectedStatuses);
19
- const results = await processResponseBody(result);
20
- const nextLink = getNextLink(results, nextLinkName);
21
- const values = getElements(results, itemName);
22
- return {
23
- page: values,
24
- nextPageLink: nextLink
25
- };
26
- },
27
- byPage: (settings) => {
28
- const { continuationToken } = settings ?? {};
29
- return getPageAsyncIterator(pagedResult, {
30
- pageLink: continuationToken
31
- });
32
- }
33
- };
34
- return getPagedAsyncIterator(pagedResult);
5
+ /**
6
+ * Helper to paginate results in a generic way and return a PagedAsyncIterableIterator
7
+ */
8
+ export function buildPagedAsyncIterator(client, getInitialResponse, processResponseBody, expectedStatuses, options = {}) {
9
+ const itemName = options.itemName ?? "value";
10
+ const nextLinkName = options.nextLinkName ?? "nextLink";
11
+ const nextLinkMethod = options.nextLinkMethod ?? "GET";
12
+ const apiVersion = options.apiVersion;
13
+ const nextPageRequestOptions = options.nextPageRequestOptions;
14
+ const pagedResult = {
15
+ getPage: async (pageLink) => {
16
+ let result;
17
+ if (pageLink === undefined) {
18
+ result = await getInitialResponse();
19
+ }
20
+ else {
21
+ const resolvedPageLink = apiVersion ? addApiVersionToUrl(pageLink, apiVersion) : pageLink;
22
+ result =
23
+ nextLinkMethod === "POST"
24
+ ? await client.pathUnchecked(resolvedPageLink).post(nextPageRequestOptions)
25
+ : await client.pathUnchecked(resolvedPageLink).get(nextPageRequestOptions);
26
+ }
27
+ checkPagingRequest(result, expectedStatuses);
28
+ const results = await processResponseBody(result);
29
+ const nextLink = getNextLink(results, nextLinkName);
30
+ const values = getElements(results, itemName);
31
+ return {
32
+ page: values,
33
+ nextPageLink: nextLink,
34
+ };
35
+ },
36
+ byPage: (settings) => {
37
+ const { continuationToken } = settings ?? {};
38
+ return getPageAsyncIterator(pagedResult, {
39
+ pageLink: continuationToken,
40
+ });
41
+ },
42
+ };
43
+ return getPagedAsyncIterator(pagedResult);
35
44
  }
45
+ /**
46
+ * returns an async iterator that iterates over results. It also has a `byPage`
47
+ * method that returns pages of items at once.
48
+ *
49
+ * @param pagedResult - an object that specifies how to get pages.
50
+ * @returns a paged async iterator that iterates over results.
51
+ */
36
52
  function getPagedAsyncIterator(pagedResult) {
37
- const iter = getItemAsyncIterator(pagedResult);
38
- return {
39
- next() {
40
- return iter.next();
41
- },
42
- [Symbol.asyncIterator]() {
43
- return this;
44
- },
45
- byPage: pagedResult?.byPage ?? ((settings) => {
46
- const { continuationToken } = settings ?? {};
47
- return getPageAsyncIterator(pagedResult, {
48
- pageLink: continuationToken
49
- });
50
- })
51
- };
53
+ const iter = getItemAsyncIterator(pagedResult);
54
+ return {
55
+ next() {
56
+ return iter.next();
57
+ },
58
+ [Symbol.asyncIterator]() {
59
+ return this;
60
+ },
61
+ byPage: pagedResult?.byPage ??
62
+ ((settings) => {
63
+ const { continuationToken } = settings ?? {};
64
+ return getPageAsyncIterator(pagedResult, {
65
+ pageLink: continuationToken,
66
+ });
67
+ }),
68
+ };
52
69
  }
53
70
  async function* getItemAsyncIterator(pagedResult) {
54
- const pages = getPageAsyncIterator(pagedResult);
55
- for await (const page of pages) {
56
- yield* page;
57
- }
71
+ const pages = getPageAsyncIterator(pagedResult);
72
+ for await (const page of pages) {
73
+ yield* page;
74
+ }
58
75
  }
59
76
  async function* getPageAsyncIterator(pagedResult, options = {}) {
60
- const { pageLink } = options;
61
- let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);
62
- if (!response) {
63
- return;
64
- }
65
- let result = response.page;
66
- result.continuationToken = response.nextPageLink;
67
- yield result;
68
- while (response.nextPageLink) {
69
- response = await pagedResult.getPage(response.nextPageLink);
77
+ const { pageLink } = options;
78
+ let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);
70
79
  if (!response) {
71
- return;
80
+ return;
72
81
  }
73
- result = response.page;
82
+ let result = response.page;
74
83
  result.continuationToken = response.nextPageLink;
75
84
  yield result;
76
- }
85
+ while (response.nextPageLink) {
86
+ response = await pagedResult.getPage(response.nextPageLink);
87
+ if (!response) {
88
+ return;
89
+ }
90
+ result = response.page;
91
+ result.continuationToken = response.nextPageLink;
92
+ yield result;
93
+ }
77
94
  }
95
+ /**
96
+ * Gets for the value of nextLink in the body
97
+ */
78
98
  function getNextLink(body, nextLinkName) {
79
- if (!nextLinkName) {
80
- return void 0;
81
- }
82
- const nextLink = body[nextLinkName];
83
- if (typeof nextLink !== "string" && typeof nextLink !== "undefined" && nextLink !== null) {
84
- throw new RestError(
85
- `Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`
86
- );
87
- }
88
- if (nextLink === null) {
89
- return void 0;
90
- }
91
- return nextLink;
99
+ if (!nextLinkName) {
100
+ return undefined;
101
+ }
102
+ const nextLink = body[nextLinkName];
103
+ if (typeof nextLink !== "string" && typeof nextLink !== "undefined" && nextLink !== null) {
104
+ throw new RestError(`Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`);
105
+ }
106
+ if (nextLink === null) {
107
+ return undefined;
108
+ }
109
+ return nextLink;
92
110
  }
111
+ /**
112
+ * Gets the elements of the current request in the body.
113
+ */
93
114
  function getElements(body, itemName) {
94
- const value = body[itemName];
95
- if (!Array.isArray(value)) {
96
- throw new RestError(
97
- `Couldn't paginate response
98
- Body doesn't contain an array property with name: ${itemName}`
99
- );
100
- }
101
- return value ?? [];
115
+ const value = body[itemName];
116
+ if (!Array.isArray(value)) {
117
+ throw new RestError(`Couldn't paginate response\n Body doesn't contain an array property with name: ${itemName}`);
118
+ }
119
+ return value ?? [];
102
120
  }
121
+ /**
122
+ * Checks if a request failed
123
+ */
103
124
  function checkPagingRequest(response, expectedStatuses) {
104
- if (!expectedStatuses.includes(response.status)) {
105
- throw createRestError(
106
- `Pagination failed with unexpected statusCode ${response.status}`,
107
- response
108
- );
109
- }
125
+ if (!expectedStatuses.includes(response.status)) {
126
+ throw createRestError(`Pagination failed with unexpected statusCode ${response.status}`, response);
127
+ }
110
128
  }
129
+ /**
130
+ * Adds the api-version query parameter on a URL if it's not present.
131
+ * @param url - the URL to modify
132
+ * @param apiVersion - the API version to set
133
+ * @returns - the URL with the api-version query parameter set
134
+ */
111
135
  function addApiVersionToUrl(url, apiVersion) {
112
- const urlObj = new URL(url, "https://microsoft.com");
113
- if (!urlObj.searchParams.get("api-version")) {
114
- return `${url}${Array.from(urlObj.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
115
- }
116
- return url;
136
+ // The base URL is only used for parsing and won't appear in the returned URL
137
+ const urlObj = new URL(url, "https://microsoft.com");
138
+ if (!urlObj.searchParams.get("api-version")) {
139
+ // Append one if there is no apiVersion
140
+ return `${url}${Array.from(urlObj.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
141
+ }
142
+ return url;
117
143
  }
118
- export {
119
- buildPagedAsyncIterator
120
- };
144
+ //# sourceMappingURL=pagingHelpers.js.map
@@ -1,7 +1 @@
1
- {
2
- "version": 3,
3
- "sources": ["/mnt/vss/_work/1/s/sdk/ai/ai-projects/src/static-helpers/pagingHelpers.ts"],
4
- "sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { PageSettings, PagedAsyncIterableIterator } from \"@azure/core-paging\";\nimport type { Client, PathUncheckedResponse } from \"@azure-rest/core-client\";\nimport { createRestError } from \"@azure-rest/core-client\";\nimport { RestError } from \"@azure/core-rest-pipeline\";\nimport type { KnownApiVersions } from \"../models/models.js\";\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 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?: KnownApiVersions;\n nextPageRequestOptions?: Record<string, unknown>;\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 nextPageRequestOptions = options.nextPageRequestOptions;\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(nextPageRequestOptions)\n : await client.pathUnchecked(resolvedPageLink).get(nextPageRequestOptions);\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
- }
1
+ {"version":3,"file":"pagingHelpers.js","sourceRoot":"","sources":["../../../src/static-helpers/pagingHelpers.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { PageSettings, PagedAsyncIterableIterator } from \"@azure/core-paging\";\nimport type { Client, PathUncheckedResponse } from \"@azure-rest/core-client\";\nimport { createRestError } from \"@azure-rest/core-client\";\nimport { RestError } from \"@azure/core-rest-pipeline\";\nimport type { KnownApiVersions } from \"../models/models.js\";\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 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?: KnownApiVersions;\n nextPageRequestOptions?: Record<string, unknown>;\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 nextPageRequestOptions = options.nextPageRequestOptions;\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(nextPageRequestOptions)\n : await client.pathUnchecked(resolvedPageLink).get(nextPageRequestOptions);\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"]}
@@ -1,84 +1,107 @@
1
+ // Copyright (c) Microsoft Corporation.
2
+ // Licensed under the MIT License.
1
3
  import { createHttpPoller } from "@azure/core-lro";
2
4
  import { createRestError } from "@azure-rest/core-client";
3
- function getLongRunningPoller(client, processResponseBody, expectedStatuses, options) {
4
- const { restoreFrom, getInitialResponse, apiVersion, pollHeaders, statusNormalizations } = options;
5
- if (!restoreFrom && !getInitialResponse) {
6
- throw new Error("Either restoreFrom or getInitialResponse must be specified");
7
- }
8
- let initialResponse = void 0;
9
- const pollAbortController = new AbortController();
10
- const poller = {
11
- sendInitialRequest: async () => {
12
- if (!getInitialResponse) {
13
- throw new Error("getInitialResponse is required when initializing a new poller");
14
- }
15
- initialResponse = await getInitialResponse();
16
- return getLroResponse(initialResponse, expectedStatuses, statusNormalizations);
17
- },
18
- sendPollRequest: async (path, pollOptions) => {
19
- function abortListener() {
20
- pollAbortController.abort();
21
- }
22
- const abortSignal = pollAbortController.signal;
23
- if (options.abortSignal?.aborted) {
24
- pollAbortController.abort();
25
- } else if (pollOptions?.abortSignal?.aborted) {
26
- pollAbortController.abort();
27
- } else if (!abortSignal.aborted) {
28
- options.abortSignal?.addEventListener("abort", abortListener, {
29
- once: true
30
- });
31
- pollOptions?.abortSignal?.addEventListener("abort", abortListener, {
32
- once: true
33
- });
34
- }
35
- let response;
36
- try {
37
- const pollingPath = apiVersion ? addApiVersionToUrl(path, apiVersion) : path;
38
- response = await client.pathUnchecked(pollingPath).get({ abortSignal, headers: pollHeaders });
39
- } finally {
40
- options.abortSignal?.removeEventListener("abort", abortListener);
41
- pollOptions?.abortSignal?.removeEventListener("abort", abortListener);
42
- }
43
- return getLroResponse(response, expectedStatuses, statusNormalizations);
5
+ export function getLongRunningPoller(client, processResponseBody, expectedStatuses, options) {
6
+ const { restoreFrom, getInitialResponse, apiVersion, pollHeaders, statusNormalizations } = options;
7
+ if (!restoreFrom && !getInitialResponse) {
8
+ throw new Error("Either restoreFrom or getInitialResponse must be specified");
44
9
  }
45
- };
46
- return createHttpPoller(poller, {
47
- intervalInMs: options?.updateIntervalInMs,
48
- resourceLocationConfig: options?.resourceLocationConfig,
49
- restoreFrom: options?.restoreFrom,
50
- processResult: (result) => {
51
- return processResponseBody(result);
52
- }
53
- });
10
+ let initialResponse = undefined;
11
+ const pollAbortController = new AbortController();
12
+ const poller = {
13
+ sendInitialRequest: async () => {
14
+ if (!getInitialResponse) {
15
+ throw new Error("getInitialResponse is required when initializing a new poller");
16
+ }
17
+ initialResponse = await getInitialResponse();
18
+ return getLroResponse(initialResponse, expectedStatuses, statusNormalizations);
19
+ },
20
+ sendPollRequest: async (path, pollOptions) => {
21
+ // The poll request would both listen to the user provided abort signal and the poller's own abort signal
22
+ function abortListener() {
23
+ pollAbortController.abort();
24
+ }
25
+ const abortSignal = pollAbortController.signal;
26
+ if (options.abortSignal?.aborted) {
27
+ pollAbortController.abort();
28
+ }
29
+ else if (pollOptions?.abortSignal?.aborted) {
30
+ pollAbortController.abort();
31
+ }
32
+ else if (!abortSignal.aborted) {
33
+ options.abortSignal?.addEventListener("abort", abortListener, {
34
+ once: true,
35
+ });
36
+ pollOptions?.abortSignal?.addEventListener("abort", abortListener, {
37
+ once: true,
38
+ });
39
+ }
40
+ let response;
41
+ try {
42
+ const pollingPath = apiVersion ? addApiVersionToUrl(path, apiVersion) : path;
43
+ response = await client
44
+ .pathUnchecked(pollingPath)
45
+ .get({ abortSignal, headers: pollHeaders });
46
+ }
47
+ finally {
48
+ options.abortSignal?.removeEventListener("abort", abortListener);
49
+ pollOptions?.abortSignal?.removeEventListener("abort", abortListener);
50
+ }
51
+ return getLroResponse(response, expectedStatuses, statusNormalizations);
52
+ },
53
+ };
54
+ return createHttpPoller(poller, {
55
+ intervalInMs: options?.updateIntervalInMs,
56
+ resourceLocationConfig: options?.resourceLocationConfig,
57
+ restoreFrom: options?.restoreFrom,
58
+ processResult: (result) => {
59
+ return processResponseBody(result);
60
+ },
61
+ });
54
62
  }
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
+ */
55
69
  function getLroResponse(response, expectedStatuses, statusNormalizations) {
56
- if (!expectedStatuses.includes(response.status)) {
57
- throw createRestError(response);
58
- }
59
- const body = response.body;
60
- const rawStatus = body?.["status"];
61
- const normalizedBody = statusNormalizations && typeof rawStatus === "string" && rawStatus in statusNormalizations ? { ...body, status: statusNormalizations[rawStatus] } : body;
62
- return {
63
- flatResponse: response,
64
- rawResponse: {
65
- ...response,
66
- statusCode: Number.parseInt(response.status),
67
- body: normalizedBody
70
+ if (!expectedStatuses.includes(response.status)) {
71
+ throw createRestError(response);
68
72
  }
69
- };
73
+ const body = response.body;
74
+ const rawStatus = body?.["status"];
75
+ const normalizedBody = statusNormalizations && typeof rawStatus === "string" && rawStatus in statusNormalizations
76
+ ? { ...body, status: statusNormalizations[rawStatus] }
77
+ : body;
78
+ return {
79
+ flatResponse: response,
80
+ rawResponse: {
81
+ ...response,
82
+ statusCode: Number.parseInt(response.status),
83
+ body: normalizedBody,
84
+ },
85
+ };
70
86
  }
87
+ /**
88
+ * Sets the api-version query parameter on a URL, replacing any existing value.
89
+ * @param url - the URL to modify
90
+ * @param apiVersion - the API version to set
91
+ * @returns - the URL with the api-version query parameter set
92
+ */
71
93
  function addApiVersionToUrl(url, apiVersion) {
72
- const urlObj = new URL(url, "https://microsoft.com");
73
- const existingVersion = urlObj.searchParams.get("api-version");
74
- if (!existingVersion) {
75
- return `${url}${Array.from(urlObj.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
76
- }
77
- if (existingVersion === apiVersion) {
78
- return url;
79
- }
80
- return url.replace(`api-version=${existingVersion}`, `api-version=${apiVersion}`);
94
+ // The base URL is only used for parsing and won't appear in the returned URL
95
+ const urlObj = new URL(url, "https://microsoft.com");
96
+ const existingVersion = urlObj.searchParams.get("api-version");
97
+ if (!existingVersion) {
98
+ // Append one if there is no apiVersion
99
+ return `${url}${Array.from(urlObj.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
100
+ }
101
+ if (existingVersion === apiVersion) {
102
+ return url;
103
+ }
104
+ // Replace the service-returned api-version with the client's configured version
105
+ return url.replace(`api-version=${existingVersion}`, `api-version=${apiVersion}`);
81
106
  }
82
- export {
83
- getLongRunningPoller
84
- };
107
+ //# sourceMappingURL=pollingHelpers.js.map
@@ -1,7 +1 @@
1
- {
2
- "version": 3,
3
- "sources": ["/mnt/vss/_work/1/s/sdk/ai/ai-projects/src/static-helpers/pollingHelpers.ts"],
4
- "sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type {\n PollerLike,\n OperationState,\n OperationStatus,\n ResourceLocationConfig,\n RunningOperation,\n OperationResponse,\n} from \"@azure/core-lro\";\nimport { createHttpPoller } from \"@azure/core-lro\";\n\nimport type { Client, PathUncheckedResponse } from \"@azure-rest/core-client\";\nimport { createRestError } from \"@azure-rest/core-client\";\nimport type { AbortSignalLike } from \"@azure/abort-controller\";\nimport type { KnownApiVersions } from \"../models/models.js\";\n\nexport interface GetLongRunningPollerOptions<TResponse> {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /**\n * The signal which can be used to abort requests.\n */\n abortSignal?: AbortSignalLike;\n /**\n * The potential location of the result of the LRO if specified by the LRO extension in the swagger.\n */\n resourceLocationConfig?: ResourceLocationConfig;\n /**\n * The original url of the LRO\n * Should not be null when restoreFrom is set\n */\n initialRequestUrl?: string;\n /**\n * A serialized poller which can be used to resume an existing paused Long-Running-Operation.\n */\n restoreFrom?: string;\n /**\n * The api-version of the LRO\n */\n apiVersion?: KnownApiVersions;\n /**\n * Additional headers to include on poll requests (e.g. feature-flag headers required by the endpoint).\n */\n pollHeaders?: Record<string, string>;\n /**\n * Optional mapping from service-specific status values to the core-lro status values\n * (\"running\", \"succeeded\", \"failed\", \"canceled\"). Use this when the service returns\n * non-standard terminal status strings (e.g. \"completed\" instead of \"succeeded\").\n */\n statusNormalizations?: Record<string, OperationStatus>;\n /**\n * The function to get the initial response\n */\n getInitialResponse?: () => PromiseLike<TResponse>;\n}\nexport function getLongRunningPoller<TResponse extends PathUncheckedResponse, TResult = void>(\n client: Client,\n processResponseBody: (result: TResponse) => Promise<TResult>,\n expectedStatuses: string[],\n options: GetLongRunningPollerOptions<TResponse>,\n): PollerLike<OperationState<TResult>, TResult> {\n const { restoreFrom, getInitialResponse, apiVersion, pollHeaders, statusNormalizations } =\n options;\n if (!restoreFrom && !getInitialResponse) {\n throw new Error(\"Either restoreFrom or getInitialResponse must be specified\");\n }\n let initialResponse: TResponse | undefined = undefined;\n const pollAbortController = new AbortController();\n const poller: RunningOperation<TResponse> = {\n sendInitialRequest: async () => {\n if (!getInitialResponse) {\n throw new Error(\"getInitialResponse is required when initializing a new poller\");\n }\n initialResponse = await getInitialResponse();\n return getLroResponse(initialResponse, expectedStatuses, statusNormalizations);\n },\n sendPollRequest: async (\n path: string,\n pollOptions?: {\n abortSignal?: AbortSignalLike;\n },\n ) => {\n // The poll request would both listen to the user provided abort signal and the poller's own abort signal\n function abortListener(): void {\n pollAbortController.abort();\n }\n const abortSignal = pollAbortController.signal;\n if (options.abortSignal?.aborted) {\n pollAbortController.abort();\n } else if (pollOptions?.abortSignal?.aborted) {\n pollAbortController.abort();\n } else if (!abortSignal.aborted) {\n options.abortSignal?.addEventListener(\"abort\", abortListener, {\n once: true,\n });\n pollOptions?.abortSignal?.addEventListener(\"abort\", abortListener, {\n once: true,\n });\n }\n let response;\n try {\n const pollingPath = apiVersion ? addApiVersionToUrl(path, apiVersion) : path;\n response = await client\n .pathUnchecked(pollingPath)\n .get({ abortSignal, headers: pollHeaders });\n } finally {\n options.abortSignal?.removeEventListener(\"abort\", abortListener);\n pollOptions?.abortSignal?.removeEventListener(\"abort\", abortListener);\n }\n\n return getLroResponse(response as TResponse, expectedStatuses, statusNormalizations);\n },\n };\n return createHttpPoller(poller, {\n intervalInMs: options?.updateIntervalInMs,\n resourceLocationConfig: options?.resourceLocationConfig,\n restoreFrom: options?.restoreFrom,\n processResult: (result: unknown) => {\n return processResponseBody(result as TResponse);\n },\n });\n}\n/**\n * Converts a Rest Client response to a response that the LRO implementation understands\n * @param response - a rest client http response\n * @param deserializeFn - deserialize function to convert Rest response to modular output\n * @returns - An LRO response that the LRO implementation understands\n */\nfunction getLroResponse<TResponse extends PathUncheckedResponse>(\n response: TResponse,\n expectedStatuses: string[],\n statusNormalizations?: Record<string, OperationStatus>,\n): OperationResponse<TResponse> {\n if (!expectedStatuses.includes(response.status)) {\n throw createRestError(response);\n }\n\n const body = response.body as Record<string, unknown> | undefined;\n const rawStatus = body?.[\"status\"];\n const normalizedBody =\n statusNormalizations && typeof rawStatus === \"string\" && rawStatus in statusNormalizations\n ? { ...body, status: statusNormalizations[rawStatus] }\n : body;\n\n return {\n flatResponse: response,\n rawResponse: {\n ...response,\n statusCode: Number.parseInt(response.status),\n body: normalizedBody,\n },\n };\n}\n\n/**\n * Sets the api-version query parameter on a URL, replacing any existing value.\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 const existingVersion = urlObj.searchParams.get(\"api-version\");\n if (!existingVersion) {\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\n if (existingVersion === apiVersion) {\n return url;\n }\n // Replace the service-returned api-version with the client's configured version\n return url.replace(`api-version=${existingVersion}`, `api-version=${apiVersion}`);\n}\n"],
5
- "mappings": "AAWA,SAAS,wBAAwB;AAGjC,SAAS,uBAAuB;AA2CzB,SAAS,qBACd,QACA,qBACA,kBACA,SAC8C;AAC9C,QAAM,EAAE,aAAa,oBAAoB,YAAY,aAAa,qBAAqB,IACrF;AACF,MAAI,CAAC,eAAe,CAAC,oBAAoB;AACvC,UAAM,IAAI,MAAM,4DAA4D;AAAA,EAC9E;AACA,MAAI,kBAAyC;AAC7C,QAAM,sBAAsB,IAAI,gBAAgB;AAChD,QAAM,SAAsC;AAAA,IAC1C,oBAAoB,YAAY;AAC9B,UAAI,CAAC,oBAAoB;AACvB,cAAM,IAAI,MAAM,+DAA+D;AAAA,MACjF;AACA,wBAAkB,MAAM,mBAAmB;AAC3C,aAAO,eAAe,iBAAiB,kBAAkB,oBAAoB;AAAA,IAC/E;AAAA,IACA,iBAAiB,OACf,MACA,gBAGG;AAEH,eAAS,gBAAsB;AAC7B,4BAAoB,MAAM;AAAA,MAC5B;AACA,YAAM,cAAc,oBAAoB;AACxC,UAAI,QAAQ,aAAa,SAAS;AAChC,4BAAoB,MAAM;AAAA,MAC5B,WAAW,aAAa,aAAa,SAAS;AAC5C,4BAAoB,MAAM;AAAA,MAC5B,WAAW,CAAC,YAAY,SAAS;AAC/B,gBAAQ,aAAa,iBAAiB,SAAS,eAAe;AAAA,UAC5D,MAAM;AAAA,QACR,CAAC;AACD,qBAAa,aAAa,iBAAiB,SAAS,eAAe;AAAA,UACjE,MAAM;AAAA,QACR,CAAC;AAAA,MACH;AACA,UAAI;AACJ,UAAI;AACF,cAAM,cAAc,aAAa,mBAAmB,MAAM,UAAU,IAAI;AACxE,mBAAW,MAAM,OACd,cAAc,WAAW,EACzB,IAAI,EAAE,aAAa,SAAS,YAAY,CAAC;AAAA,MAC9C,UAAE;AACA,gBAAQ,aAAa,oBAAoB,SAAS,aAAa;AAC/D,qBAAa,aAAa,oBAAoB,SAAS,aAAa;AAAA,MACtE;AAEA,aAAO,eAAe,UAAuB,kBAAkB,oBAAoB;AAAA,IACrF;AAAA,EACF;AACA,SAAO,iBAAiB,QAAQ;AAAA,IAC9B,cAAc,SAAS;AAAA,IACvB,wBAAwB,SAAS;AAAA,IACjC,aAAa,SAAS;AAAA,IACtB,eAAe,CAAC,WAAoB;AAClC,aAAO,oBAAoB,MAAmB;AAAA,IAChD;AAAA,EACF,CAAC;AACH;AAOA,SAAS,eACP,UACA,kBACA,sBAC8B;AAC9B,MAAI,CAAC,iBAAiB,SAAS,SAAS,MAAM,GAAG;AAC/C,UAAM,gBAAgB,QAAQ;AAAA,EAChC;AAEA,QAAM,OAAO,SAAS;AACtB,QAAM,YAAY,OAAO,QAAQ;AACjC,QAAM,iBACJ,wBAAwB,OAAO,cAAc,YAAY,aAAa,uBAClE,EAAE,GAAG,MAAM,QAAQ,qBAAqB,SAAS,EAAE,IACnD;AAEN,SAAO;AAAA,IACL,cAAc;AAAA,IACd,aAAa;AAAA,MACX,GAAG;AAAA,MACH,YAAY,OAAO,SAAS,SAAS,MAAM;AAAA,MAC3C,MAAM;AAAA,IACR;AAAA,EACF;AACF;AAQA,SAAS,mBAAmB,KAAa,YAA4B;AAEnE,QAAM,SAAS,IAAI,IAAI,KAAK,uBAAuB;AACnD,QAAM,kBAAkB,OAAO,aAAa,IAAI,aAAa;AAC7D,MAAI,CAAC,iBAAiB;AAEpB,WAAO,GAAG,GAAG,GACX,MAAM,KAAK,OAAO,aAAa,KAAK,CAAC,EAAE,SAAS,IAAI,MAAM,GAC5D,eAAe,UAAU;AAAA,EAC3B;AAEA,MAAI,oBAAoB,YAAY;AAClC,WAAO;AAAA,EACT;AAEA,SAAO,IAAI,QAAQ,eAAe,eAAe,IAAI,eAAe,UAAU,EAAE;AAClF;",
6
- "names": []
7
- }
1
+ {"version":3,"file":"pollingHelpers.js","sourceRoot":"","sources":["../../../src/static-helpers/pollingHelpers.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type {\n PollerLike,\n OperationState,\n OperationStatus,\n ResourceLocationConfig,\n RunningOperation,\n OperationResponse,\n} from \"@azure/core-lro\";\nimport { createHttpPoller } from \"@azure/core-lro\";\n\nimport type { Client, PathUncheckedResponse } from \"@azure-rest/core-client\";\nimport { createRestError } from \"@azure-rest/core-client\";\nimport type { AbortSignalLike } from \"@azure/abort-controller\";\nimport type { KnownApiVersions } from \"../models/models.js\";\n\nexport interface GetLongRunningPollerOptions<TResponse> {\n /** Delay to wait until next poll, in milliseconds. */\n updateIntervalInMs?: number;\n /**\n * The signal which can be used to abort requests.\n */\n abortSignal?: AbortSignalLike;\n /**\n * The potential location of the result of the LRO if specified by the LRO extension in the swagger.\n */\n resourceLocationConfig?: ResourceLocationConfig;\n /**\n * The original url of the LRO\n * Should not be null when restoreFrom is set\n */\n initialRequestUrl?: string;\n /**\n * A serialized poller which can be used to resume an existing paused Long-Running-Operation.\n */\n restoreFrom?: string;\n /**\n * The api-version of the LRO\n */\n apiVersion?: KnownApiVersions;\n /**\n * Additional headers to include on poll requests (e.g. feature-flag headers required by the endpoint).\n */\n pollHeaders?: Record<string, string>;\n /**\n * Optional mapping from service-specific status values to the core-lro status values\n * (\"running\", \"succeeded\", \"failed\", \"canceled\"). Use this when the service returns\n * non-standard terminal status strings (e.g. \"completed\" instead of \"succeeded\").\n */\n statusNormalizations?: Record<string, OperationStatus>;\n /**\n * The function to get the initial response\n */\n getInitialResponse?: () => PromiseLike<TResponse>;\n}\nexport function getLongRunningPoller<TResponse extends PathUncheckedResponse, TResult = void>(\n client: Client,\n processResponseBody: (result: TResponse) => Promise<TResult>,\n expectedStatuses: string[],\n options: GetLongRunningPollerOptions<TResponse>,\n): PollerLike<OperationState<TResult>, TResult> {\n const { restoreFrom, getInitialResponse, apiVersion, pollHeaders, statusNormalizations } =\n options;\n if (!restoreFrom && !getInitialResponse) {\n throw new Error(\"Either restoreFrom or getInitialResponse must be specified\");\n }\n let initialResponse: TResponse | undefined = undefined;\n const pollAbortController = new AbortController();\n const poller: RunningOperation<TResponse> = {\n sendInitialRequest: async () => {\n if (!getInitialResponse) {\n throw new Error(\"getInitialResponse is required when initializing a new poller\");\n }\n initialResponse = await getInitialResponse();\n return getLroResponse(initialResponse, expectedStatuses, statusNormalizations);\n },\n sendPollRequest: async (\n path: string,\n pollOptions?: {\n abortSignal?: AbortSignalLike;\n },\n ) => {\n // The poll request would both listen to the user provided abort signal and the poller's own abort signal\n function abortListener(): void {\n pollAbortController.abort();\n }\n const abortSignal = pollAbortController.signal;\n if (options.abortSignal?.aborted) {\n pollAbortController.abort();\n } else if (pollOptions?.abortSignal?.aborted) {\n pollAbortController.abort();\n } else if (!abortSignal.aborted) {\n options.abortSignal?.addEventListener(\"abort\", abortListener, {\n once: true,\n });\n pollOptions?.abortSignal?.addEventListener(\"abort\", abortListener, {\n once: true,\n });\n }\n let response;\n try {\n const pollingPath = apiVersion ? addApiVersionToUrl(path, apiVersion) : path;\n response = await client\n .pathUnchecked(pollingPath)\n .get({ abortSignal, headers: pollHeaders });\n } finally {\n options.abortSignal?.removeEventListener(\"abort\", abortListener);\n pollOptions?.abortSignal?.removeEventListener(\"abort\", abortListener);\n }\n\n return getLroResponse(response as TResponse, expectedStatuses, statusNormalizations);\n },\n };\n return createHttpPoller(poller, {\n intervalInMs: options?.updateIntervalInMs,\n resourceLocationConfig: options?.resourceLocationConfig,\n restoreFrom: options?.restoreFrom,\n processResult: (result: unknown) => {\n return processResponseBody(result as TResponse);\n },\n });\n}\n/**\n * Converts a Rest Client response to a response that the LRO implementation understands\n * @param response - a rest client http response\n * @param deserializeFn - deserialize function to convert Rest response to modular output\n * @returns - An LRO response that the LRO implementation understands\n */\nfunction getLroResponse<TResponse extends PathUncheckedResponse>(\n response: TResponse,\n expectedStatuses: string[],\n statusNormalizations?: Record<string, OperationStatus>,\n): OperationResponse<TResponse> {\n if (!expectedStatuses.includes(response.status)) {\n throw createRestError(response);\n }\n\n const body = response.body as Record<string, unknown> | undefined;\n const rawStatus = body?.[\"status\"];\n const normalizedBody =\n statusNormalizations && typeof rawStatus === \"string\" && rawStatus in statusNormalizations\n ? { ...body, status: statusNormalizations[rawStatus] }\n : body;\n\n return {\n flatResponse: response,\n rawResponse: {\n ...response,\n statusCode: Number.parseInt(response.status),\n body: normalizedBody,\n },\n };\n}\n\n/**\n * Sets the api-version query parameter on a URL, replacing any existing value.\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 const existingVersion = urlObj.searchParams.get(\"api-version\");\n if (!existingVersion) {\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\n if (existingVersion === apiVersion) {\n return url;\n }\n // Replace the service-returned api-version with the client's configured version\n return url.replace(`api-version=${existingVersion}`, `api-version=${apiVersion}`);\n}\n"]}
@@ -1,18 +1,20 @@
1
- function serializeRecord(item, excludes, serializer) {
2
- const nextExcludes = excludes ?? [];
3
- const res = {};
4
- for (const key of Object.keys(item)) {
5
- if (nextExcludes.includes(key) || item[key] === void 0) {
6
- continue;
1
+ // Copyright (c) Microsoft Corporation.
2
+ // Licensed under the MIT License.
3
+ // eslint-disable-next-line @typescript-eslint/explicit-function-return-type, @typescript-eslint/explicit-module-boundary-types
4
+ export function serializeRecord(item, excludes, serializer) {
5
+ const nextExcludes = excludes ?? [];
6
+ const res = {};
7
+ for (const key of Object.keys(item)) {
8
+ if (nextExcludes.includes(key) || item[key] === undefined) {
9
+ continue;
10
+ }
11
+ if (serializer) {
12
+ res[key] = serializer(item[key]);
13
+ }
14
+ else {
15
+ res[key] = item[key];
16
+ }
7
17
  }
8
- if (serializer) {
9
- res[key] = serializer(item[key]);
10
- } else {
11
- res[key] = item[key];
12
- }
13
- }
14
- return res;
18
+ return res;
15
19
  }
16
- export {
17
- serializeRecord
18
- };
20
+ //# sourceMappingURL=serialize-record.js.map
@@ -1,7 +1 @@
1
- {
2
- "version": 3,
3
- "sources": ["/mnt/vss/_work/1/s/sdk/ai/ai-projects/src/static-helpers/serialization/serialize-record.ts"],
4
- "sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n// eslint-disable-next-line @typescript-eslint/explicit-function-return-type, @typescript-eslint/explicit-module-boundary-types\nexport function serializeRecord(item: any, excludes?: string[], serializer?: (item: any) => any) {\n const nextExcludes = excludes ?? [];\n const res: any = {};\n for (const key of Object.keys(item)) {\n if (nextExcludes.includes(key) || item[key] === undefined) {\n continue;\n }\n if (serializer) {\n res[key] = serializer(item[key]);\n } else {\n res[key] = item[key] as any;\n }\n }\n return res;\n}\n"],
5
- "mappings": "AAIO,SAAS,gBAAgB,MAAW,UAAqB,YAAiC;AAC/F,QAAM,eAAe,YAAY,CAAC;AAClC,QAAM,MAAW,CAAC;AAClB,aAAW,OAAO,OAAO,KAAK,IAAI,GAAG;AACnC,QAAI,aAAa,SAAS,GAAG,KAAK,KAAK,GAAG,MAAM,QAAW;AACzD;AAAA,IACF;AACA,QAAI,YAAY;AACd,UAAI,GAAG,IAAI,WAAW,KAAK,GAAG,CAAC;AAAA,IACjC,OAAO;AACL,UAAI,GAAG,IAAI,KAAK,GAAG;AAAA,IACrB;AAAA,EACF;AACA,SAAO;AACT;",
6
- "names": []
7
- }
1
+ {"version":3,"file":"serialize-record.js","sourceRoot":"","sources":["../../../../src/static-helpers/serialization/serialize-record.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,+HAA+H;AAC/H,MAAM,UAAU,eAAe,CAAC,IAAS,EAAE,QAAmB,EAAE,UAA+B;IAC7F,MAAM,YAAY,GAAG,QAAQ,IAAI,EAAE,CAAC;IACpC,MAAM,GAAG,GAAQ,EAAE,CAAC;IACpB,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACpC,IAAI,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,SAAS,EAAE,CAAC;YAC1D,SAAS;QACX,CAAC;QACD,IAAI,UAAU,EAAE,CAAC;YACf,GAAG,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAQ,CAAC;QAC9B,CAAC;IACH,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n// eslint-disable-next-line @typescript-eslint/explicit-function-return-type, @typescript-eslint/explicit-module-boundary-types\nexport function serializeRecord(item: any, excludes?: string[], serializer?: (item: any) => any) {\n const nextExcludes = excludes ?? [];\n const res: any = {};\n for (const key of Object.keys(item)) {\n if (nextExcludes.includes(key) || item[key] === undefined) {\n continue;\n }\n if (serializer) {\n res[key] = serializer(item[key]);\n } else {\n res[key] = item[key] as any;\n }\n }\n return res;\n}\n"]}