@azure/ai-projects 2.0.0 → 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 (319) hide show
  1. package/README.md +5 -5
  2. package/dist/browser/api/aiProjectContext.d.ts.map +1 -1
  3. package/dist/browser/api/aiProjectContext.js +2 -1
  4. package/dist/browser/api/aiProjectContext.js.map +1 -1
  5. package/dist/browser/api/beta/memoryStores/operations.d.ts.map +1 -1
  6. package/dist/browser/api/beta/memoryStores/operations.js +11 -0
  7. package/dist/browser/api/beta/memoryStores/operations.js.map +1 -1
  8. package/dist/browser/api/datasets/operations.d.ts.map +1 -1
  9. package/dist/browser/api/datasets/operations.js +9 -8
  10. package/dist/browser/api/datasets/operations.js.map +1 -1
  11. package/dist/browser/constants.d.ts +1 -1
  12. package/dist/browser/constants.js +1 -1
  13. package/dist/browser/constants.js.map +1 -1
  14. package/dist/browser/static-helpers/pollingHelpers.d.ts +11 -1
  15. package/dist/browser/static-helpers/pollingHelpers.d.ts.map +1 -1
  16. package/dist/browser/static-helpers/pollingHelpers.js +21 -9
  17. package/dist/browser/static-helpers/pollingHelpers.js.map +1 -1
  18. package/dist/commonjs/aiProjectClient.js +1 -0
  19. package/dist/commonjs/aiProjectClient.js.map +1 -1
  20. package/dist/commonjs/api/agents/index.js +1 -0
  21. package/dist/commonjs/api/agents/index.js.map +1 -1
  22. package/dist/commonjs/api/agents/operations.js +1 -0
  23. package/dist/commonjs/api/agents/operations.js.map +1 -1
  24. package/dist/commonjs/api/agents/options.js +1 -0
  25. package/dist/commonjs/api/agents/options.js.map +1 -1
  26. package/dist/commonjs/api/aiProjectContext.d.ts.map +1 -1
  27. package/dist/commonjs/api/aiProjectContext.js +3 -1
  28. package/dist/commonjs/api/aiProjectContext.js.map +3 -3
  29. package/dist/commonjs/api/beta/evaluationTaxonomies/index.js +1 -0
  30. package/dist/commonjs/api/beta/evaluationTaxonomies/index.js.map +1 -1
  31. package/dist/commonjs/api/beta/evaluationTaxonomies/operations.js +1 -0
  32. package/dist/commonjs/api/beta/evaluationTaxonomies/operations.js.map +1 -1
  33. package/dist/commonjs/api/beta/evaluationTaxonomies/options.js +1 -0
  34. package/dist/commonjs/api/beta/evaluationTaxonomies/options.js.map +1 -1
  35. package/dist/commonjs/api/beta/evaluators/index.js +1 -0
  36. package/dist/commonjs/api/beta/evaluators/index.js.map +1 -1
  37. package/dist/commonjs/api/beta/evaluators/operations.js +1 -0
  38. package/dist/commonjs/api/beta/evaluators/operations.js.map +1 -1
  39. package/dist/commonjs/api/beta/evaluators/options.js +1 -0
  40. package/dist/commonjs/api/beta/evaluators/options.js.map +1 -1
  41. package/dist/commonjs/api/beta/insights/index.js +1 -0
  42. package/dist/commonjs/api/beta/insights/index.js.map +1 -1
  43. package/dist/commonjs/api/beta/insights/operations.js +1 -0
  44. package/dist/commonjs/api/beta/insights/operations.js.map +1 -1
  45. package/dist/commonjs/api/beta/insights/options.js +1 -0
  46. package/dist/commonjs/api/beta/insights/options.js.map +1 -1
  47. package/dist/commonjs/api/beta/memoryStores/index.js +1 -0
  48. package/dist/commonjs/api/beta/memoryStores/index.js.map +1 -1
  49. package/dist/commonjs/api/beta/memoryStores/operations.d.ts.map +1 -1
  50. package/dist/commonjs/api/beta/memoryStores/operations.js +13 -1
  51. package/dist/commonjs/api/beta/memoryStores/operations.js.map +3 -3
  52. package/dist/commonjs/api/beta/memoryStores/options.js +1 -0
  53. package/dist/commonjs/api/beta/memoryStores/options.js.map +1 -1
  54. package/dist/commonjs/api/beta/redTeams/index.js +1 -0
  55. package/dist/commonjs/api/beta/redTeams/index.js.map +1 -1
  56. package/dist/commonjs/api/beta/redTeams/operations.js +1 -0
  57. package/dist/commonjs/api/beta/redTeams/operations.js.map +1 -1
  58. package/dist/commonjs/api/beta/redTeams/options.js +1 -0
  59. package/dist/commonjs/api/beta/redTeams/options.js.map +1 -1
  60. package/dist/commonjs/api/beta/schedules/index.js +1 -0
  61. package/dist/commonjs/api/beta/schedules/index.js.map +1 -1
  62. package/dist/commonjs/api/beta/schedules/operations.js +1 -0
  63. package/dist/commonjs/api/beta/schedules/operations.js.map +1 -1
  64. package/dist/commonjs/api/beta/schedules/options.js +1 -0
  65. package/dist/commonjs/api/beta/schedules/options.js.map +1 -1
  66. package/dist/commonjs/api/connections/index.js +1 -0
  67. package/dist/commonjs/api/connections/index.js.map +1 -1
  68. package/dist/commonjs/api/connections/operations.js +1 -0
  69. package/dist/commonjs/api/connections/operations.js.map +1 -1
  70. package/dist/commonjs/api/connections/options.js +1 -0
  71. package/dist/commonjs/api/connections/options.js.map +1 -1
  72. package/dist/commonjs/api/datasets/index.js +1 -0
  73. package/dist/commonjs/api/datasets/index.js.map +1 -1
  74. package/dist/commonjs/api/datasets/operations.d.ts.map +1 -1
  75. package/dist/commonjs/api/datasets/operations.js +10 -8
  76. package/dist/commonjs/api/datasets/operations.js.map +3 -3
  77. package/dist/commonjs/api/datasets/options.js +1 -0
  78. package/dist/commonjs/api/datasets/options.js.map +1 -1
  79. package/dist/commonjs/api/deployments/index.js +1 -0
  80. package/dist/commonjs/api/deployments/index.js.map +1 -1
  81. package/dist/commonjs/api/deployments/operations.js +1 -0
  82. package/dist/commonjs/api/deployments/operations.js.map +1 -1
  83. package/dist/commonjs/api/deployments/options.js +1 -0
  84. package/dist/commonjs/api/deployments/options.js.map +1 -1
  85. package/dist/commonjs/api/evaluationRules/index.js +1 -0
  86. package/dist/commonjs/api/evaluationRules/index.js.map +1 -1
  87. package/dist/commonjs/api/evaluationRules/operations.js +1 -0
  88. package/dist/commonjs/api/evaluationRules/operations.js.map +1 -1
  89. package/dist/commonjs/api/evaluationRules/options.js +1 -0
  90. package/dist/commonjs/api/evaluationRules/options.js.map +1 -1
  91. package/dist/commonjs/api/index.js +1 -0
  92. package/dist/commonjs/api/index.js.map +1 -1
  93. package/dist/commonjs/api/indexes/index.js +1 -0
  94. package/dist/commonjs/api/indexes/index.js.map +1 -1
  95. package/dist/commonjs/api/indexes/operations.js +1 -0
  96. package/dist/commonjs/api/indexes/operations.js.map +1 -1
  97. package/dist/commonjs/api/indexes/options.js +1 -0
  98. package/dist/commonjs/api/indexes/options.js.map +1 -1
  99. package/dist/commonjs/api/telemetry/index.js +1 -0
  100. package/dist/commonjs/api/telemetry/index.js.map +1 -1
  101. package/dist/commonjs/api/telemetry/operations.js +1 -0
  102. package/dist/commonjs/api/telemetry/operations.js.map +1 -1
  103. package/dist/commonjs/classic/agents/index.js +1 -0
  104. package/dist/commonjs/classic/agents/index.js.map +1 -1
  105. package/dist/commonjs/classic/beta/evaluationTaxonomies/index.js +1 -0
  106. package/dist/commonjs/classic/beta/evaluationTaxonomies/index.js.map +1 -1
  107. package/dist/commonjs/classic/beta/evaluators/index.js +1 -0
  108. package/dist/commonjs/classic/beta/evaluators/index.js.map +1 -1
  109. package/dist/commonjs/classic/beta/index.js +1 -0
  110. package/dist/commonjs/classic/beta/index.js.map +1 -1
  111. package/dist/commonjs/classic/beta/insights/index.js +1 -0
  112. package/dist/commonjs/classic/beta/insights/index.js.map +1 -1
  113. package/dist/commonjs/classic/beta/memoryStores/index.js +1 -0
  114. package/dist/commonjs/classic/beta/memoryStores/index.js.map +1 -1
  115. package/dist/commonjs/classic/beta/redTeams/index.js +1 -0
  116. package/dist/commonjs/classic/beta/redTeams/index.js.map +1 -1
  117. package/dist/commonjs/classic/beta/schedules/index.js +1 -0
  118. package/dist/commonjs/classic/beta/schedules/index.js.map +1 -1
  119. package/dist/commonjs/classic/connections/index.js +1 -0
  120. package/dist/commonjs/classic/connections/index.js.map +1 -1
  121. package/dist/commonjs/classic/datasets/index.js +1 -0
  122. package/dist/commonjs/classic/datasets/index.js.map +1 -1
  123. package/dist/commonjs/classic/deployments/index.js +1 -0
  124. package/dist/commonjs/classic/deployments/index.js.map +1 -1
  125. package/dist/commonjs/classic/evaluationRules/index.js +1 -0
  126. package/dist/commonjs/classic/evaluationRules/index.js.map +1 -1
  127. package/dist/commonjs/classic/index.js +1 -0
  128. package/dist/commonjs/classic/index.js.map +1 -1
  129. package/dist/commonjs/classic/indexes/index.js +1 -0
  130. package/dist/commonjs/classic/indexes/index.js.map +1 -1
  131. package/dist/commonjs/classic/telemetry/index.js +1 -0
  132. package/dist/commonjs/classic/telemetry/index.js.map +1 -1
  133. package/dist/commonjs/constants.d.ts +1 -1
  134. package/dist/commonjs/constants.js +2 -1
  135. package/dist/commonjs/constants.js.map +2 -2
  136. package/dist/commonjs/getCustomFetch.js +1 -0
  137. package/dist/commonjs/getCustomFetch.js.map +1 -1
  138. package/dist/commonjs/index.js +1 -0
  139. package/dist/commonjs/index.js.map +1 -1
  140. package/dist/commonjs/logger.js +1 -0
  141. package/dist/commonjs/logger.js.map +1 -1
  142. package/dist/commonjs/models/index.js +1 -0
  143. package/dist/commonjs/models/index.js.map +1 -1
  144. package/dist/commonjs/models/models.js +1 -0
  145. package/dist/commonjs/models/models.js.map +1 -1
  146. package/dist/commonjs/overwriteOpenAIClient.js +1 -0
  147. package/dist/commonjs/overwriteOpenAIClient.js.map +1 -1
  148. package/dist/commonjs/static-helpers/pagingHelpers.js +1 -0
  149. package/dist/commonjs/static-helpers/pagingHelpers.js.map +1 -1
  150. package/dist/commonjs/static-helpers/pollingHelpers.d.ts +11 -1
  151. package/dist/commonjs/static-helpers/pollingHelpers.d.ts.map +1 -1
  152. package/dist/commonjs/static-helpers/pollingHelpers.js +16 -8
  153. package/dist/commonjs/static-helpers/pollingHelpers.js.map +3 -3
  154. package/dist/commonjs/static-helpers/serialization/serialize-record.js +1 -0
  155. package/dist/commonjs/static-helpers/serialization/serialize-record.js.map +1 -1
  156. package/dist/commonjs/static-helpers/urlTemplate.js +1 -0
  157. package/dist/commonjs/static-helpers/urlTemplate.js.map +1 -1
  158. package/dist/commonjs/tsdoc-metadata.json +1 -1
  159. package/dist/commonjs/util.js +1 -0
  160. package/dist/commonjs/util.js.map +1 -1
  161. package/dist/esm/aiProjectClient.js +119 -94
  162. package/dist/esm/aiProjectClient.js.map +1 -7
  163. package/dist/esm/api/agents/index.js +4 -28
  164. package/dist/esm/api/agents/index.js.map +1 -7
  165. package/dist/esm/api/agents/operations.js +375 -473
  166. package/dist/esm/api/agents/operations.js.map +1 -7
  167. package/dist/esm/api/agents/options.js +4 -0
  168. package/dist/esm/api/agents/options.js.map +1 -7
  169. package/dist/esm/api/aiProjectContext.d.ts.map +1 -1
  170. package/dist/esm/api/aiProjectContext.js +22 -19
  171. package/dist/esm/api/aiProjectContext.js.map +1 -7
  172. package/dist/esm/api/beta/evaluationTaxonomies/index.js +4 -8
  173. package/dist/esm/api/beta/evaluationTaxonomies/index.js.map +1 -7
  174. package/dist/esm/api/beta/evaluationTaxonomies/operations.js +150 -183
  175. package/dist/esm/api/beta/evaluationTaxonomies/operations.js.map +1 -7
  176. package/dist/esm/api/beta/evaluationTaxonomies/options.js +4 -0
  177. package/dist/esm/api/beta/evaluationTaxonomies/options.js.map +1 -7
  178. package/dist/esm/api/beta/evaluators/index.js +4 -16
  179. package/dist/esm/api/beta/evaluators/index.js.map +1 -7
  180. package/dist/esm/api/beta/evaluators/operations.js +192 -243
  181. package/dist/esm/api/beta/evaluators/operations.js.map +1 -7
  182. package/dist/esm/api/beta/evaluators/options.js +4 -0
  183. package/dist/esm/api/beta/evaluators/options.js.map +1 -7
  184. package/dist/esm/api/beta/insights/index.js +4 -6
  185. package/dist/esm/api/beta/insights/index.js.map +1 -7
  186. package/dist/esm/api/beta/insights/operations.js +109 -126
  187. package/dist/esm/api/beta/insights/operations.js.map +1 -7
  188. package/dist/esm/api/beta/insights/options.js +4 -0
  189. package/dist/esm/api/beta/insights/options.js.map +1 -7
  190. package/dist/esm/api/beta/memoryStores/index.js +4 -22
  191. package/dist/esm/api/beta/memoryStores/index.js.map +1 -7
  192. package/dist/esm/api/beta/memoryStores/operations.d.ts.map +1 -1
  193. package/dist/esm/api/beta/memoryStores/operations.js +305 -363
  194. package/dist/esm/api/beta/memoryStores/operations.js.map +1 -7
  195. package/dist/esm/api/beta/memoryStores/options.js +4 -0
  196. package/dist/esm/api/beta/memoryStores/options.js.map +1 -7
  197. package/dist/esm/api/beta/redTeams/index.js +4 -6
  198. package/dist/esm/api/beta/redTeams/index.js.map +1 -7
  199. package/dist/esm/api/beta/redTeams/operations.js +95 -119
  200. package/dist/esm/api/beta/redTeams/operations.js.map +1 -7
  201. package/dist/esm/api/beta/redTeams/options.js +4 -0
  202. package/dist/esm/api/beta/redTeams/options.js.map +1 -7
  203. package/dist/esm/api/beta/schedules/index.js +4 -9
  204. package/dist/esm/api/beta/schedules/index.js.map +1 -7
  205. package/dist/esm/api/beta/schedules/operations.js +204 -248
  206. package/dist/esm/api/beta/schedules/operations.js.map +1 -7
  207. package/dist/esm/api/beta/schedules/options.js +4 -0
  208. package/dist/esm/api/beta/schedules/options.js.map +1 -7
  209. package/dist/esm/api/connections/index.js +4 -6
  210. package/dist/esm/api/connections/index.js.map +1 -7
  211. package/dist/esm/api/connections/operations.js +109 -116
  212. package/dist/esm/api/connections/operations.js.map +1 -7
  213. package/dist/esm/api/connections/options.js +4 -0
  214. package/dist/esm/api/connections/options.js.map +1 -7
  215. package/dist/esm/api/datasets/index.js +4 -18
  216. package/dist/esm/api/datasets/index.js.map +1 -7
  217. package/dist/esm/api/datasets/operations.d.ts.map +1 -1
  218. package/dist/esm/api/datasets/operations.js +288 -355
  219. package/dist/esm/api/datasets/operations.js.map +1 -7
  220. package/dist/esm/api/datasets/options.js +4 -0
  221. package/dist/esm/api/datasets/options.js.map +1 -7
  222. package/dist/esm/api/deployments/index.js +4 -5
  223. package/dist/esm/api/deployments/index.js.map +1 -7
  224. package/dist/esm/api/deployments/operations.js +57 -70
  225. package/dist/esm/api/deployments/operations.js.map +1 -7
  226. package/dist/esm/api/deployments/options.js +4 -0
  227. package/dist/esm/api/deployments/options.js.map +1 -7
  228. package/dist/esm/api/evaluationRules/index.js +4 -7
  229. package/dist/esm/api/evaluationRules/index.js.map +1 -7
  230. package/dist/esm/api/evaluationRules/operations.js +121 -144
  231. package/dist/esm/api/evaluationRules/operations.js.map +1 -7
  232. package/dist/esm/api/evaluationRules/options.js +4 -0
  233. package/dist/esm/api/evaluationRules/options.js.map +1 -7
  234. package/dist/esm/api/index.js +4 -4
  235. package/dist/esm/api/index.js.map +1 -7
  236. package/dist/esm/api/indexes/index.js +4 -8
  237. package/dist/esm/api/indexes/index.js.map +1 -7
  238. package/dist/esm/api/indexes/operations.js +116 -161
  239. package/dist/esm/api/indexes/operations.js.map +1 -7
  240. package/dist/esm/api/indexes/options.js +4 -0
  241. package/dist/esm/api/indexes/options.js.map +1 -7
  242. package/dist/esm/api/telemetry/index.js +4 -4
  243. package/dist/esm/api/telemetry/index.js.map +1 -7
  244. package/dist/esm/api/telemetry/operations.js +53 -46
  245. package/dist/esm/api/telemetry/operations.js.map +1 -7
  246. package/dist/esm/classic/agents/index.js +40 -80
  247. package/dist/esm/classic/agents/index.js.map +1 -7
  248. package/dist/esm/classic/beta/evaluationTaxonomies/index.js +15 -21
  249. package/dist/esm/classic/beta/evaluationTaxonomies/index.js.map +1 -7
  250. package/dist/esm/classic/beta/evaluators/index.js +16 -23
  251. package/dist/esm/classic/beta/evaluators/index.js.map +1 -7
  252. package/dist/esm/classic/beta/index.js +18 -18
  253. package/dist/esm/classic/beta/index.js.map +1 -7
  254. package/dist/esm/classic/beta/insights/index.js +12 -12
  255. package/dist/esm/classic/beta/insights/index.js.map +1 -7
  256. package/dist/esm/classic/beta/memoryStores/index.js +19 -29
  257. package/dist/esm/classic/beta/memoryStores/index.js.map +1 -7
  258. package/dist/esm/classic/beta/redTeams/index.js +12 -12
  259. package/dist/esm/classic/beta/redTeams/index.js.map +1 -7
  260. package/dist/esm/classic/beta/schedules/index.js +16 -23
  261. package/dist/esm/classic/beta/schedules/index.js.map +1 -7
  262. package/dist/esm/classic/connections/index.js +13 -13
  263. package/dist/esm/classic/connections/index.js.map +1 -7
  264. package/dist/esm/classic/datasets/index.js +19 -29
  265. package/dist/esm/classic/datasets/index.js.map +1 -7
  266. package/dist/esm/classic/deployments/index.js +11 -11
  267. package/dist/esm/classic/deployments/index.js.map +1 -7
  268. package/dist/esm/classic/evaluationRules/index.js +13 -13
  269. package/dist/esm/classic/evaluationRules/index.js.map +1 -7
  270. package/dist/esm/classic/index.js +4 -0
  271. package/dist/esm/classic/index.js.map +1 -7
  272. package/dist/esm/classic/indexes/index.js +14 -14
  273. package/dist/esm/classic/indexes/index.js.map +1 -7
  274. package/dist/esm/classic/telemetry/index.js +7 -9
  275. package/dist/esm/classic/telemetry/index.js.map +1 -7
  276. package/dist/esm/constants.d.ts +1 -1
  277. package/dist/esm/constants.js +11 -6
  278. package/dist/esm/constants.js.map +1 -7
  279. package/dist/esm/getCustomFetch.js +40 -33
  280. package/dist/esm/getCustomFetch.js.map +1 -7
  281. package/dist/esm/index.js +4 -4
  282. package/dist/esm/index.js.map +1 -7
  283. package/dist/esm/logger.js +4 -4
  284. package/dist/esm/logger.js.map +1 -7
  285. package/dist/esm/models/index.js +4 -0
  286. package/dist/esm/models/index.js.map +1 -7
  287. package/dist/esm/models/models.js +3709 -4160
  288. package/dist/esm/models/models.js.map +1 -7
  289. package/dist/esm/overwriteOpenAIClient.js +13 -13
  290. package/dist/esm/overwriteOpenAIClient.js.map +1 -7
  291. package/dist/esm/static-helpers/pagingHelpers.js +123 -99
  292. package/dist/esm/static-helpers/pagingHelpers.js.map +1 -7
  293. package/dist/esm/static-helpers/pollingHelpers.d.ts +11 -1
  294. package/dist/esm/static-helpers/pollingHelpers.d.ts.map +1 -1
  295. package/dist/esm/static-helpers/pollingHelpers.js +99 -69
  296. package/dist/esm/static-helpers/pollingHelpers.js.map +1 -7
  297. package/dist/esm/static-helpers/serialization/serialize-record.js +18 -16
  298. package/dist/esm/static-helpers/serialization/serialize-record.js.map +1 -7
  299. package/dist/esm/static-helpers/urlTemplate.js +169 -142
  300. package/dist/esm/static-helpers/urlTemplate.js.map +1 -7
  301. package/dist/esm/util.js +84 -63
  302. package/dist/esm/util.js.map +1 -7
  303. package/dist/react-native/api/aiProjectContext.d.ts.map +1 -1
  304. package/dist/react-native/api/aiProjectContext.js +2 -1
  305. package/dist/react-native/api/aiProjectContext.js.map +1 -1
  306. package/dist/react-native/api/beta/memoryStores/operations.d.ts.map +1 -1
  307. package/dist/react-native/api/beta/memoryStores/operations.js +11 -0
  308. package/dist/react-native/api/beta/memoryStores/operations.js.map +1 -1
  309. package/dist/react-native/api/datasets/operations.d.ts.map +1 -1
  310. package/dist/react-native/api/datasets/operations.js +9 -8
  311. package/dist/react-native/api/datasets/operations.js.map +1 -1
  312. package/dist/react-native/constants.d.ts +1 -1
  313. package/dist/react-native/constants.js +1 -1
  314. package/dist/react-native/constants.js.map +1 -1
  315. package/dist/react-native/static-helpers/pollingHelpers.d.ts +11 -1
  316. package/dist/react-native/static-helpers/pollingHelpers.d.ts.map +1 -1
  317. package/dist/react-native/static-helpers/pollingHelpers.js +21 -9
  318. package/dist/react-native/static-helpers/pollingHelpers.js.map +1 -1
  319. package/package.json +9 -9
@@ -3,7 +3,7 @@
3
3
  import { createHttpPoller } from "@azure/core-lro";
4
4
  import { createRestError } from "@azure-rest/core-client";
5
5
  export function getLongRunningPoller(client, processResponseBody, expectedStatuses, options) {
6
- const { restoreFrom, getInitialResponse, apiVersion } = options;
6
+ const { restoreFrom, getInitialResponse, apiVersion, pollHeaders, statusNormalizations } = options;
7
7
  if (!restoreFrom && !getInitialResponse) {
8
8
  throw new Error("Either restoreFrom or getInitialResponse must be specified");
9
9
  }
@@ -15,7 +15,7 @@ export function getLongRunningPoller(client, processResponseBody, expectedStatus
15
15
  throw new Error("getInitialResponse is required when initializing a new poller");
16
16
  }
17
17
  initialResponse = await getInitialResponse();
18
- return getLroResponse(initialResponse, expectedStatuses);
18
+ return getLroResponse(initialResponse, expectedStatuses, statusNormalizations);
19
19
  },
20
20
  sendPollRequest: async (path, pollOptions) => {
21
21
  // The poll request would both listen to the user provided abort signal and the poller's own abort signal
@@ -40,13 +40,15 @@ export function getLongRunningPoller(client, processResponseBody, expectedStatus
40
40
  let response;
41
41
  try {
42
42
  const pollingPath = apiVersion ? addApiVersionToUrl(path, apiVersion) : path;
43
- response = await client.pathUnchecked(pollingPath).get({ abortSignal });
43
+ response = await client
44
+ .pathUnchecked(pollingPath)
45
+ .get({ abortSignal, headers: pollHeaders });
44
46
  }
45
47
  finally {
46
48
  options.abortSignal?.removeEventListener("abort", abortListener);
47
49
  pollOptions?.abortSignal?.removeEventListener("abort", abortListener);
48
50
  }
49
- return getLroResponse(response, expectedStatuses);
51
+ return getLroResponse(response, expectedStatuses, statusNormalizations);
50
52
  },
51
53
  };
52
54
  return createHttpPoller(poller, {
@@ -64,21 +66,26 @@ export function getLongRunningPoller(client, processResponseBody, expectedStatus
64
66
  * @param deserializeFn - deserialize function to convert Rest response to modular output
65
67
  * @returns - An LRO response that the LRO implementation understands
66
68
  */
67
- function getLroResponse(response, expectedStatuses) {
69
+ function getLroResponse(response, expectedStatuses, statusNormalizations) {
68
70
  if (!expectedStatuses.includes(response.status)) {
69
71
  throw createRestError(response);
70
72
  }
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;
71
78
  return {
72
79
  flatResponse: response,
73
80
  rawResponse: {
74
81
  ...response,
75
82
  statusCode: Number.parseInt(response.status),
76
- body: response.body,
83
+ body: normalizedBody,
77
84
  },
78
85
  };
79
86
  }
80
87
  /**
81
- * Adds the api-version query parameter on a URL if it's not present.
88
+ * Sets the api-version query parameter on a URL, replacing any existing value.
82
89
  * @param url - the URL to modify
83
90
  * @param apiVersion - the API version to set
84
91
  * @returns - the URL with the api-version query parameter set
@@ -86,10 +93,15 @@ function getLroResponse(response, expectedStatuses) {
86
93
  function addApiVersionToUrl(url, apiVersion) {
87
94
  // The base URL is only used for parsing and won't appear in the returned URL
88
95
  const urlObj = new URL(url, "https://microsoft.com");
89
- if (!urlObj.searchParams.get("api-version")) {
96
+ const existingVersion = urlObj.searchParams.get("api-version");
97
+ if (!existingVersion) {
90
98
  // Append one if there is no apiVersion
91
99
  return `${url}${Array.from(urlObj.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
92
100
  }
93
- return url;
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}`);
94
106
  }
95
107
  //# sourceMappingURL=pollingHelpers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"pollingHelpers.js","sourceRoot":"","sources":["../../../src/static-helpers/pollingHelpers.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AASlC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAGnD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAiC1D,MAAM,UAAU,oBAAoB,CAClC,MAAc,EACd,mBAA4D,EAC5D,gBAA0B,EAC1B,OAA+C;IAE/C,MAAM,EAAE,WAAW,EAAE,kBAAkB,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAChE,IAAI,CAAC,WAAW,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACxC,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;IAChF,CAAC;IACD,IAAI,eAAe,GAA0B,SAAS,CAAC;IACvD,MAAM,mBAAmB,GAAG,IAAI,eAAe,EAAE,CAAC;IAClD,MAAM,MAAM,GAAgC;QAC1C,kBAAkB,EAAE,KAAK,IAAI,EAAE;YAC7B,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBACxB,MAAM,IAAI,KAAK,CAAC,+DAA+D,CAAC,CAAC;YACnF,CAAC;YACD,eAAe,GAAG,MAAM,kBAAkB,EAAE,CAAC;YAC7C,OAAO,cAAc,CAAC,eAAe,EAAE,gBAAgB,CAAC,CAAC;QAC3D,CAAC;QACD,eAAe,EAAE,KAAK,EACpB,IAAY,EACZ,WAEC,EACD,EAAE;YACF,yGAAyG;YACzG,SAAS,aAAa;gBACpB,mBAAmB,CAAC,KAAK,EAAE,CAAC;YAC9B,CAAC;YACD,MAAM,WAAW,GAAG,mBAAmB,CAAC,MAAM,CAAC;YAC/C,IAAI,OAAO,CAAC,WAAW,EAAE,OAAO,EAAE,CAAC;gBACjC,mBAAmB,CAAC,KAAK,EAAE,CAAC;YAC9B,CAAC;iBAAM,IAAI,WAAW,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;gBAC7C,mBAAmB,CAAC,KAAK,EAAE,CAAC;YAC9B,CAAC;iBAAM,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;gBAChC,OAAO,CAAC,WAAW,EAAE,gBAAgB,CAAC,OAAO,EAAE,aAAa,EAAE;oBAC5D,IAAI,EAAE,IAAI;iBACX,CAAC,CAAC;gBACH,WAAW,EAAE,WAAW,EAAE,gBAAgB,CAAC,OAAO,EAAE,aAAa,EAAE;oBACjE,IAAI,EAAE,IAAI;iBACX,CAAC,CAAC;YACL,CAAC;YACD,IAAI,QAAQ,CAAC;YACb,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gBAC7E,QAAQ,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;YAC1E,CAAC;oBAAS,CAAC;gBACT,OAAO,CAAC,WAAW,EAAE,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;gBACjE,WAAW,EAAE,WAAW,EAAE,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;YACxE,CAAC;YAED,OAAO,cAAc,CAAC,QAAqB,EAAE,gBAAgB,CAAC,CAAC;QACjE,CAAC;KACF,CAAC;IACF,OAAO,gBAAgB,CAAC,MAAM,EAAE;QAC9B,YAAY,EAAE,OAAO,EAAE,kBAAkB;QACzC,sBAAsB,EAAE,OAAO,EAAE,sBAAsB;QACvD,WAAW,EAAE,OAAO,EAAE,WAAW;QACjC,aAAa,EAAE,CAAC,MAAe,EAAE,EAAE;YACjC,OAAO,mBAAmB,CAAC,MAAmB,CAAC,CAAC;QAClD,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AACD;;;;;GAKG;AACH,SAAS,cAAc,CACrB,QAAmB,EACnB,gBAA0B;IAE1B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAChD,MAAM,eAAe,CAAC,QAAQ,CAAC,CAAC;IAClC,CAAC;IAED,OAAO;QACL,YAAY,EAAE,QAAQ;QACtB,WAAW,EAAE;YACX,GAAG,QAAQ;YACX,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC;YAC5C,IAAI,EAAE,QAAQ,CAAC,IAAI;SACpB;KACF,CAAC;AACJ,CAAC;AAED;;;;;GAKG;AACH,SAAS,kBAAkB,CAAC,GAAW,EAAE,UAAkB;IACzD,6EAA6E;IAC7E,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,uBAAuB,CAAC,CAAC;IACrD,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;QAC5C,uCAAuC;QACvC,OAAO,GAAG,GAAG,GACX,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAC5D,eAAe,UAAU,EAAE,CAAC;IAC9B,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type {\n PollerLike,\n OperationState,\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 * 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 } = 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);\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.pathUnchecked(pollingPath).get({ abortSignal });\n } finally {\n options.abortSignal?.removeEventListener(\"abort\", abortListener);\n pollOptions?.abortSignal?.removeEventListener(\"abort\", abortListener);\n }\n\n return getLroResponse(response as TResponse, expectedStatuses);\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): OperationResponse<TResponse> {\n if (!expectedStatuses.includes(response.status)) {\n throw createRestError(response);\n }\n\n return {\n flatResponse: response,\n rawResponse: {\n ...response,\n statusCode: Number.parseInt(response.status),\n body: response.body,\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
+ {"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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@azure/ai-projects",
3
- "version": "2.0.0",
3
+ "version": "2.0.2",
4
4
  "description": "Azure AI Projects client library.",
5
5
  "engines": {
6
6
  "node": ">=20.0.0"
@@ -59,31 +59,31 @@
59
59
  },
60
60
  "devDependencies": {
61
61
  "@azure-rest/ai-inference": "^1.0.0-beta.6",
62
- "@azure/arm-cognitiveservices": "7.6.0",
62
+ "@azure/arm-cognitiveservices": "8.1.0",
63
63
  "@azure/monitor-opentelemetry": "^1.16.0",
64
64
  "@azure/opentelemetry-instrumentation-azure-sdk": "1.0.0-beta.7",
65
65
  "@opentelemetry/api": "^1.9.0",
66
66
  "@opentelemetry/instrumentation": "^0.57.0",
67
67
  "@opentelemetry/sdk-trace-node": "^2.0.0",
68
68
  "@types/node": "^20.19.25",
69
- "@vitest/browser-playwright": "^4.0.8",
70
- "@vitest/coverage-istanbul": "^4.0.8",
69
+ "@vitest/browser-playwright": "^4.1.2",
70
+ "@vitest/coverage-istanbul": "^4.1.2",
71
71
  "@modelcontextprotocol/sdk": "^1.25.1",
72
72
  "zod": "^4.2.1",
73
73
  "cross-env": "^10.1.0",
74
74
  "dotenv": "^16.6.1",
75
75
  "eslint": "^9.39.1",
76
76
  "mkdirp": "^3.0.1",
77
- "playwright": "^1.56.1",
77
+ "playwright": "^1.58.2",
78
78
  "prettier": "^3.6.2",
79
79
  "rimraf": "^6.1.0",
80
- "typescript": "~5.9.3",
81
- "vitest": "^4.0.8",
80
+ "typescript": "~6.0.2",
81
+ "vitest": "^4.1.2",
82
82
  "@azure-tools/test-credential": "^2.1.2",
83
83
  "@azure-tools/test-recorder": "^4.1.1",
84
- "@azure-tools/test-utils-vitest": "^2.0.1",
85
84
  "@azure/dev-tool": "^1.0.0",
86
- "@azure/eslint-plugin-azure-sdk": "^3.0.0"
85
+ "@azure/eslint-plugin-azure-sdk": "^3.0.0",
86
+ "@azure-tools/test-utils-vitest": "^2.0.1"
87
87
  },
88
88
  "exports": {
89
89
  "./package.json": "./package.json",