@azure/arm-confidentialledger 1.3.0-beta.3 → 2.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (435) hide show
  1. package/README.md +11 -11
  2. package/dist/browser/api/confidentialLedgerContext.d.ts +22 -0
  3. package/dist/browser/api/confidentialLedgerContext.js +26 -0
  4. package/dist/browser/api/confidentialLedgerContext.js.map +1 -0
  5. package/dist/browser/api/index.d.ts +5 -0
  6. package/dist/browser/api/index.js +5 -0
  7. package/dist/browser/api/index.js.map +1 -0
  8. package/dist/browser/api/ledger/index.d.ts +3 -0
  9. package/dist/browser/api/ledger/index.js +4 -0
  10. package/dist/browser/api/ledger/index.js.map +1 -0
  11. package/dist/browser/api/ledger/operations.d.ts +35 -0
  12. package/dist/browser/api/ledger/operations.js +224 -0
  13. package/dist/browser/api/ledger/operations.js.map +1 -0
  14. package/dist/browser/api/ledger/options.d.ts +35 -0
  15. package/dist/browser/api/ledger/options.js +4 -0
  16. package/dist/browser/api/ledger/options.js.map +1 -0
  17. package/dist/browser/api/operations/index.d.ts +3 -0
  18. package/dist/browser/api/operations/index.js +4 -0
  19. package/dist/browser/api/operations/index.js.map +1 -0
  20. package/dist/browser/api/operations/operations.d.ts +10 -0
  21. package/dist/browser/api/operations/operations.js +31 -0
  22. package/dist/browser/api/operations/operations.js.map +1 -0
  23. package/dist/browser/api/operations/options.d.ts +5 -0
  24. package/dist/browser/api/operations/options.js +4 -0
  25. package/dist/browser/api/operations/options.js.map +1 -0
  26. package/dist/browser/api/operations.d.ts +9 -0
  27. package/dist/browser/api/operations.js +34 -0
  28. package/dist/browser/api/operations.js.map +1 -0
  29. package/dist/browser/api/options.d.ts +5 -0
  30. package/dist/browser/api/options.js +4 -0
  31. package/dist/browser/api/options.js.map +1 -0
  32. package/dist/browser/classic/index.d.ts +3 -0
  33. package/dist/browser/classic/index.js +4 -0
  34. package/dist/browser/classic/index.js.map +1 -0
  35. package/dist/browser/classic/ledger/index.d.ts +41 -0
  36. package/dist/browser/classic/ledger/index.js +53 -0
  37. package/dist/browser/classic/ledger/index.js.map +1 -0
  38. package/dist/browser/classic/operations/index.d.ts +11 -0
  39. package/dist/browser/classic/operations/index.js +14 -0
  40. package/dist/browser/classic/operations/index.js.map +1 -0
  41. package/dist/browser/confidentialLedgerClient.d.ts +20 -26
  42. package/dist/browser/confidentialLedgerClient.js +36 -123
  43. package/dist/browser/confidentialLedgerClient.js.map +1 -1
  44. package/dist/browser/index.d.ts +15 -3
  45. package/dist/browser/index.js +7 -11
  46. package/dist/browser/index.js.map +1 -1
  47. package/dist/browser/logger.d.ts +2 -0
  48. package/dist/browser/logger.js +5 -0
  49. package/dist/browser/logger.js.map +1 -0
  50. package/dist/browser/models/index.d.ts +2 -724
  51. package/dist/browser/models/index.js +3 -113
  52. package/dist/browser/models/index.js.map +1 -1
  53. package/dist/browser/models/models.d.ts +408 -0
  54. package/dist/browser/models/models.js +362 -0
  55. package/dist/browser/models/models.js.map +1 -0
  56. package/dist/browser/restorePollerHelpers.d.ts +21 -0
  57. package/dist/browser/restorePollerHelpers.js +97 -0
  58. package/dist/browser/restorePollerHelpers.js.map +1 -0
  59. package/dist/browser/static-helpers/cloudSettingHelpers.d.ts +22 -0
  60. package/dist/browser/static-helpers/cloudSettingHelpers.js +38 -0
  61. package/dist/browser/static-helpers/cloudSettingHelpers.js.map +1 -0
  62. package/dist/browser/static-helpers/pagingHelpers.d.ts +74 -0
  63. package/dist/browser/static-helpers/pagingHelpers.js +143 -0
  64. package/dist/browser/static-helpers/pagingHelpers.js.map +1 -0
  65. package/dist/browser/static-helpers/pollingHelpers.d.ts +34 -0
  66. package/dist/browser/static-helpers/pollingHelpers.js +95 -0
  67. package/dist/browser/static-helpers/pollingHelpers.js.map +1 -0
  68. package/dist/browser/static-helpers/simplePollerHelpers.d.ts +73 -0
  69. package/dist/browser/static-helpers/simplePollerHelpers.js +44 -0
  70. package/dist/browser/static-helpers/simplePollerHelpers.js.map +1 -0
  71. package/dist/browser/static-helpers/urlTemplate.d.ts +5 -0
  72. package/dist/browser/static-helpers/urlTemplate.js +200 -0
  73. package/dist/browser/static-helpers/urlTemplate.js.map +1 -0
  74. package/dist/commonjs/api/confidentialLedgerContext.d.ts +22 -0
  75. package/dist/commonjs/api/confidentialLedgerContext.js +47 -0
  76. package/dist/commonjs/api/confidentialLedgerContext.js.map +7 -0
  77. package/dist/commonjs/api/index.d.ts +5 -0
  78. package/dist/commonjs/api/index.js +31 -0
  79. package/dist/commonjs/api/index.js.map +7 -0
  80. package/dist/commonjs/api/ledger/index.d.ts +3 -0
  81. package/dist/commonjs/api/ledger/index.js +40 -0
  82. package/dist/commonjs/api/ledger/index.js.map +7 -0
  83. package/dist/commonjs/api/ledger/operations.d.ts +35 -0
  84. package/dist/commonjs/api/ledger/operations.js +321 -0
  85. package/dist/commonjs/api/ledger/operations.js.map +7 -0
  86. package/dist/commonjs/api/ledger/options.d.ts +35 -0
  87. package/dist/commonjs/api/ledger/options.js +16 -0
  88. package/dist/commonjs/api/ledger/options.js.map +7 -0
  89. package/dist/commonjs/api/operations/index.d.ts +3 -0
  90. package/dist/commonjs/api/operations/index.js +28 -0
  91. package/dist/commonjs/api/operations/index.js.map +7 -0
  92. package/dist/commonjs/api/operations/operations.d.ts +10 -0
  93. package/dist/commonjs/api/operations/operations.js +68 -0
  94. package/dist/commonjs/api/operations/operations.js.map +7 -0
  95. package/dist/commonjs/api/operations/options.d.ts +5 -0
  96. package/dist/commonjs/api/operations/options.js +16 -0
  97. package/dist/commonjs/api/operations/options.js.map +7 -0
  98. package/dist/commonjs/api/operations.d.ts +9 -0
  99. package/dist/commonjs/api/operations.js +65 -0
  100. package/dist/commonjs/api/operations.js.map +7 -0
  101. package/dist/commonjs/api/options.d.ts +5 -0
  102. package/dist/commonjs/api/options.js +16 -0
  103. package/dist/commonjs/api/options.js.map +7 -0
  104. package/dist/commonjs/classic/index.d.ts +3 -0
  105. package/dist/commonjs/classic/index.js +16 -0
  106. package/dist/commonjs/classic/index.js.map +7 -0
  107. package/dist/commonjs/classic/ledger/index.d.ts +41 -0
  108. package/dist/commonjs/classic/ledger/index.js +83 -0
  109. package/dist/commonjs/classic/ledger/index.js.map +7 -0
  110. package/dist/commonjs/classic/operations/index.d.ts +11 -0
  111. package/dist/commonjs/classic/operations/index.js +38 -0
  112. package/dist/commonjs/classic/operations/index.js.map +7 -0
  113. package/dist/commonjs/confidentialLedgerClient.d.ts +20 -26
  114. package/dist/commonjs/confidentialLedgerClient.js +61 -132
  115. package/dist/commonjs/confidentialLedgerClient.js.map +7 -1
  116. package/dist/commonjs/index.d.ts +15 -3
  117. package/dist/commonjs/index.js +60 -19
  118. package/dist/commonjs/index.js.map +7 -1
  119. package/dist/commonjs/logger.d.ts +2 -0
  120. package/dist/commonjs/logger.js +29 -0
  121. package/dist/commonjs/logger.js.map +7 -0
  122. package/dist/commonjs/models/index.d.ts +2 -724
  123. package/dist/commonjs/models/index.js +46 -117
  124. package/dist/commonjs/models/index.js.map +7 -1
  125. package/dist/commonjs/models/models.d.ts +408 -0
  126. package/dist/commonjs/models/models.js +398 -0
  127. package/dist/commonjs/models/models.js.map +7 -0
  128. package/dist/commonjs/restorePollerHelpers.d.ts +21 -0
  129. package/dist/commonjs/restorePollerHelpers.js +110 -0
  130. package/dist/commonjs/restorePollerHelpers.js.map +7 -0
  131. package/dist/commonjs/static-helpers/cloudSettingHelpers.d.ts +22 -0
  132. package/dist/commonjs/static-helpers/cloudSettingHelpers.js +52 -0
  133. package/dist/commonjs/static-helpers/cloudSettingHelpers.js.map +7 -0
  134. package/dist/commonjs/static-helpers/pagingHelpers.d.ts +74 -0
  135. package/dist/commonjs/static-helpers/pagingHelpers.js +143 -0
  136. package/dist/commonjs/static-helpers/pagingHelpers.js.map +7 -0
  137. package/dist/commonjs/static-helpers/pollingHelpers.d.ts +34 -0
  138. package/dist/commonjs/static-helpers/pollingHelpers.js +101 -0
  139. package/dist/commonjs/static-helpers/pollingHelpers.js.map +7 -0
  140. package/dist/commonjs/static-helpers/simplePollerHelpers.d.ts +73 -0
  141. package/dist/commonjs/static-helpers/simplePollerHelpers.js +67 -0
  142. package/dist/commonjs/static-helpers/simplePollerHelpers.js.map +7 -0
  143. package/dist/commonjs/static-helpers/urlTemplate.d.ts +5 -0
  144. package/dist/commonjs/static-helpers/urlTemplate.js +197 -0
  145. package/dist/commonjs/static-helpers/urlTemplate.js.map +7 -0
  146. package/dist/commonjs/tsdoc-metadata.json +11 -11
  147. package/dist/esm/api/confidentialLedgerContext.d.ts +22 -0
  148. package/dist/esm/api/confidentialLedgerContext.js +26 -0
  149. package/dist/esm/api/confidentialLedgerContext.js.map +1 -0
  150. package/dist/esm/api/index.d.ts +5 -0
  151. package/dist/esm/api/index.js +5 -0
  152. package/dist/esm/api/index.js.map +1 -0
  153. package/dist/esm/api/ledger/index.d.ts +3 -0
  154. package/dist/esm/api/ledger/index.js +4 -0
  155. package/dist/esm/api/ledger/index.js.map +1 -0
  156. package/dist/esm/api/ledger/operations.d.ts +35 -0
  157. package/dist/esm/api/ledger/operations.js +224 -0
  158. package/dist/esm/api/ledger/operations.js.map +1 -0
  159. package/dist/esm/api/ledger/options.d.ts +35 -0
  160. package/dist/esm/api/ledger/options.js +4 -0
  161. package/dist/esm/api/ledger/options.js.map +1 -0
  162. package/dist/esm/api/operations/index.d.ts +3 -0
  163. package/dist/esm/api/operations/index.js +4 -0
  164. package/dist/esm/api/operations/index.js.map +1 -0
  165. package/dist/esm/api/operations/operations.d.ts +10 -0
  166. package/dist/esm/api/operations/operations.js +31 -0
  167. package/dist/esm/api/operations/operations.js.map +1 -0
  168. package/dist/esm/api/operations/options.d.ts +5 -0
  169. package/dist/esm/api/operations/options.js +4 -0
  170. package/dist/esm/api/operations/options.js.map +1 -0
  171. package/dist/esm/api/operations.d.ts +9 -0
  172. package/dist/esm/api/operations.js +34 -0
  173. package/dist/esm/api/operations.js.map +1 -0
  174. package/dist/esm/api/options.d.ts +5 -0
  175. package/dist/esm/api/options.js +4 -0
  176. package/dist/esm/api/options.js.map +1 -0
  177. package/dist/esm/classic/index.d.ts +3 -0
  178. package/dist/esm/classic/index.js +4 -0
  179. package/dist/esm/classic/index.js.map +1 -0
  180. package/dist/esm/classic/ledger/index.d.ts +41 -0
  181. package/dist/esm/classic/ledger/index.js +53 -0
  182. package/dist/esm/classic/ledger/index.js.map +1 -0
  183. package/dist/esm/classic/operations/index.d.ts +11 -0
  184. package/dist/esm/classic/operations/index.js +14 -0
  185. package/dist/esm/classic/operations/index.js.map +1 -0
  186. package/dist/esm/confidentialLedgerClient.d.ts +20 -26
  187. package/dist/esm/confidentialLedgerClient.js +36 -123
  188. package/dist/esm/confidentialLedgerClient.js.map +1 -1
  189. package/dist/esm/index.d.ts +15 -3
  190. package/dist/esm/index.js +7 -11
  191. package/dist/esm/index.js.map +1 -1
  192. package/dist/esm/logger.d.ts +2 -0
  193. package/dist/esm/logger.js +5 -0
  194. package/dist/esm/logger.js.map +1 -0
  195. package/dist/esm/models/index.d.ts +2 -724
  196. package/dist/esm/models/index.js +3 -113
  197. package/dist/esm/models/index.js.map +1 -1
  198. package/dist/esm/models/models.d.ts +408 -0
  199. package/dist/esm/models/models.js +362 -0
  200. package/dist/esm/models/models.js.map +1 -0
  201. package/dist/esm/restorePollerHelpers.d.ts +21 -0
  202. package/dist/esm/restorePollerHelpers.js +97 -0
  203. package/dist/esm/restorePollerHelpers.js.map +1 -0
  204. package/dist/esm/static-helpers/cloudSettingHelpers.d.ts +22 -0
  205. package/dist/esm/static-helpers/cloudSettingHelpers.js +38 -0
  206. package/dist/esm/static-helpers/cloudSettingHelpers.js.map +1 -0
  207. package/dist/esm/static-helpers/pagingHelpers.d.ts +74 -0
  208. package/dist/esm/static-helpers/pagingHelpers.js +143 -0
  209. package/dist/esm/static-helpers/pagingHelpers.js.map +1 -0
  210. package/dist/esm/static-helpers/pollingHelpers.d.ts +34 -0
  211. package/dist/esm/static-helpers/pollingHelpers.js +95 -0
  212. package/dist/esm/static-helpers/pollingHelpers.js.map +1 -0
  213. package/dist/esm/static-helpers/simplePollerHelpers.d.ts +73 -0
  214. package/dist/esm/static-helpers/simplePollerHelpers.js +44 -0
  215. package/dist/esm/static-helpers/simplePollerHelpers.js.map +1 -0
  216. package/dist/esm/static-helpers/urlTemplate.d.ts +5 -0
  217. package/dist/esm/static-helpers/urlTemplate.js +200 -0
  218. package/dist/esm/static-helpers/urlTemplate.js.map +1 -0
  219. package/package.json +151 -100
  220. package/CHANGELOG.md +0 -179
  221. package/dist/browser/confidentialLedgerClient.d.ts.map +0 -1
  222. package/dist/browser/index.d.ts.map +0 -1
  223. package/dist/browser/lroImpl.d.ts +0 -11
  224. package/dist/browser/lroImpl.d.ts.map +0 -1
  225. package/dist/browser/lroImpl.js +0 -21
  226. package/dist/browser/lroImpl.js.map +0 -1
  227. package/dist/browser/models/index.d.ts.map +0 -1
  228. package/dist/browser/models/mappers.d.ts +0 -32
  229. package/dist/browser/models/mappers.d.ts.map +0 -1
  230. package/dist/browser/models/mappers.js +0 -885
  231. package/dist/browser/models/mappers.js.map +0 -1
  232. package/dist/browser/models/parameters.d.ts +0 -19
  233. package/dist/browser/models/parameters.d.ts.map +0 -1
  234. package/dist/browser/models/parameters.js +0 -154
  235. package/dist/browser/models/parameters.js.map +0 -1
  236. package/dist/browser/operations/index.d.ts +0 -4
  237. package/dist/browser/operations/index.d.ts.map +0 -1
  238. package/dist/browser/operations/index.js +0 -11
  239. package/dist/browser/operations/index.js.map +0 -1
  240. package/dist/browser/operations/ledger.d.ts +0 -139
  241. package/dist/browser/operations/ledger.d.ts.map +0 -1
  242. package/dist/browser/operations/ledger.js +0 -702
  243. package/dist/browser/operations/ledger.js.map +0 -1
  244. package/dist/browser/operations/managedCCFOperations.d.ts +0 -139
  245. package/dist/browser/operations/managedCCFOperations.d.ts.map +0 -1
  246. package/dist/browser/operations/managedCCFOperations.js +0 -702
  247. package/dist/browser/operations/managedCCFOperations.js.map +0 -1
  248. package/dist/browser/operations/operations.d.ts +0 -32
  249. package/dist/browser/operations/operations.d.ts.map +0 -1
  250. package/dist/browser/operations/operations.js +0 -133
  251. package/dist/browser/operations/operations.js.map +0 -1
  252. package/dist/browser/operationsInterfaces/index.d.ts +0 -4
  253. package/dist/browser/operationsInterfaces/index.d.ts.map +0 -1
  254. package/dist/browser/operationsInterfaces/index.js +0 -11
  255. package/dist/browser/operationsInterfaces/index.js.map +0 -1
  256. package/dist/browser/operationsInterfaces/ledger.d.ts +0 -103
  257. package/dist/browser/operationsInterfaces/ledger.d.ts.map +0 -1
  258. package/dist/browser/operationsInterfaces/ledger.js +0 -9
  259. package/dist/browser/operationsInterfaces/ledger.js.map +0 -1
  260. package/dist/browser/operationsInterfaces/managedCCFOperations.d.ts +0 -103
  261. package/dist/browser/operationsInterfaces/managedCCFOperations.d.ts.map +0 -1
  262. package/dist/browser/operationsInterfaces/managedCCFOperations.js +0 -9
  263. package/dist/browser/operationsInterfaces/managedCCFOperations.js.map +0 -1
  264. package/dist/browser/operationsInterfaces/operations.d.ts +0 -11
  265. package/dist/browser/operationsInterfaces/operations.d.ts.map +0 -1
  266. package/dist/browser/operationsInterfaces/operations.js +0 -9
  267. package/dist/browser/operationsInterfaces/operations.js.map +0 -1
  268. package/dist/browser/pagingHelper.d.ts +0 -13
  269. package/dist/browser/pagingHelper.d.ts.map +0 -1
  270. package/dist/browser/pagingHelper.js +0 -32
  271. package/dist/browser/pagingHelper.js.map +0 -1
  272. package/dist/commonjs/confidentialLedgerClient.d.ts.map +0 -1
  273. package/dist/commonjs/index.d.ts.map +0 -1
  274. package/dist/commonjs/lroImpl.d.ts +0 -11
  275. package/dist/commonjs/lroImpl.d.ts.map +0 -1
  276. package/dist/commonjs/lroImpl.js +0 -24
  277. package/dist/commonjs/lroImpl.js.map +0 -1
  278. package/dist/commonjs/models/index.d.ts.map +0 -1
  279. package/dist/commonjs/models/mappers.d.ts +0 -32
  280. package/dist/commonjs/models/mappers.d.ts.map +0 -1
  281. package/dist/commonjs/models/mappers.js +0 -888
  282. package/dist/commonjs/models/mappers.js.map +0 -1
  283. package/dist/commonjs/models/parameters.d.ts +0 -19
  284. package/dist/commonjs/models/parameters.d.ts.map +0 -1
  285. package/dist/commonjs/models/parameters.js +0 -157
  286. package/dist/commonjs/models/parameters.js.map +0 -1
  287. package/dist/commonjs/operations/index.d.ts +0 -4
  288. package/dist/commonjs/operations/index.d.ts.map +0 -1
  289. package/dist/commonjs/operations/index.js +0 -14
  290. package/dist/commonjs/operations/index.js.map +0 -1
  291. package/dist/commonjs/operations/ledger.d.ts +0 -139
  292. package/dist/commonjs/operations/ledger.d.ts.map +0 -1
  293. package/dist/commonjs/operations/ledger.js +0 -706
  294. package/dist/commonjs/operations/ledger.js.map +0 -1
  295. package/dist/commonjs/operations/managedCCFOperations.d.ts +0 -139
  296. package/dist/commonjs/operations/managedCCFOperations.d.ts.map +0 -1
  297. package/dist/commonjs/operations/managedCCFOperations.js +0 -706
  298. package/dist/commonjs/operations/managedCCFOperations.js.map +0 -1
  299. package/dist/commonjs/operations/operations.d.ts +0 -32
  300. package/dist/commonjs/operations/operations.d.ts.map +0 -1
  301. package/dist/commonjs/operations/operations.js +0 -137
  302. package/dist/commonjs/operations/operations.js.map +0 -1
  303. package/dist/commonjs/operationsInterfaces/index.d.ts +0 -4
  304. package/dist/commonjs/operationsInterfaces/index.d.ts.map +0 -1
  305. package/dist/commonjs/operationsInterfaces/index.js +0 -14
  306. package/dist/commonjs/operationsInterfaces/index.js.map +0 -1
  307. package/dist/commonjs/operationsInterfaces/ledger.d.ts +0 -103
  308. package/dist/commonjs/operationsInterfaces/ledger.d.ts.map +0 -1
  309. package/dist/commonjs/operationsInterfaces/ledger.js +0 -10
  310. package/dist/commonjs/operationsInterfaces/ledger.js.map +0 -1
  311. package/dist/commonjs/operationsInterfaces/managedCCFOperations.d.ts +0 -103
  312. package/dist/commonjs/operationsInterfaces/managedCCFOperations.d.ts.map +0 -1
  313. package/dist/commonjs/operationsInterfaces/managedCCFOperations.js +0 -10
  314. package/dist/commonjs/operationsInterfaces/managedCCFOperations.js.map +0 -1
  315. package/dist/commonjs/operationsInterfaces/operations.d.ts +0 -11
  316. package/dist/commonjs/operationsInterfaces/operations.d.ts.map +0 -1
  317. package/dist/commonjs/operationsInterfaces/operations.js +0 -10
  318. package/dist/commonjs/operationsInterfaces/operations.js.map +0 -1
  319. package/dist/commonjs/pagingHelper.d.ts +0 -13
  320. package/dist/commonjs/pagingHelper.d.ts.map +0 -1
  321. package/dist/commonjs/pagingHelper.js +0 -36
  322. package/dist/commonjs/pagingHelper.js.map +0 -1
  323. package/dist/esm/confidentialLedgerClient.d.ts.map +0 -1
  324. package/dist/esm/index.d.ts.map +0 -1
  325. package/dist/esm/lroImpl.d.ts +0 -11
  326. package/dist/esm/lroImpl.d.ts.map +0 -1
  327. package/dist/esm/lroImpl.js +0 -21
  328. package/dist/esm/lroImpl.js.map +0 -1
  329. package/dist/esm/models/index.d.ts.map +0 -1
  330. package/dist/esm/models/mappers.d.ts +0 -32
  331. package/dist/esm/models/mappers.d.ts.map +0 -1
  332. package/dist/esm/models/mappers.js +0 -885
  333. package/dist/esm/models/mappers.js.map +0 -1
  334. package/dist/esm/models/parameters.d.ts +0 -19
  335. package/dist/esm/models/parameters.d.ts.map +0 -1
  336. package/dist/esm/models/parameters.js +0 -154
  337. package/dist/esm/models/parameters.js.map +0 -1
  338. package/dist/esm/operations/index.d.ts +0 -4
  339. package/dist/esm/operations/index.d.ts.map +0 -1
  340. package/dist/esm/operations/index.js +0 -11
  341. package/dist/esm/operations/index.js.map +0 -1
  342. package/dist/esm/operations/ledger.d.ts +0 -139
  343. package/dist/esm/operations/ledger.d.ts.map +0 -1
  344. package/dist/esm/operations/ledger.js +0 -702
  345. package/dist/esm/operations/ledger.js.map +0 -1
  346. package/dist/esm/operations/managedCCFOperations.d.ts +0 -139
  347. package/dist/esm/operations/managedCCFOperations.d.ts.map +0 -1
  348. package/dist/esm/operations/managedCCFOperations.js +0 -702
  349. package/dist/esm/operations/managedCCFOperations.js.map +0 -1
  350. package/dist/esm/operations/operations.d.ts +0 -32
  351. package/dist/esm/operations/operations.d.ts.map +0 -1
  352. package/dist/esm/operations/operations.js +0 -133
  353. package/dist/esm/operations/operations.js.map +0 -1
  354. package/dist/esm/operationsInterfaces/index.d.ts +0 -4
  355. package/dist/esm/operationsInterfaces/index.d.ts.map +0 -1
  356. package/dist/esm/operationsInterfaces/index.js +0 -11
  357. package/dist/esm/operationsInterfaces/index.js.map +0 -1
  358. package/dist/esm/operationsInterfaces/ledger.d.ts +0 -103
  359. package/dist/esm/operationsInterfaces/ledger.d.ts.map +0 -1
  360. package/dist/esm/operationsInterfaces/ledger.js +0 -9
  361. package/dist/esm/operationsInterfaces/ledger.js.map +0 -1
  362. package/dist/esm/operationsInterfaces/managedCCFOperations.d.ts +0 -103
  363. package/dist/esm/operationsInterfaces/managedCCFOperations.d.ts.map +0 -1
  364. package/dist/esm/operationsInterfaces/managedCCFOperations.js +0 -9
  365. package/dist/esm/operationsInterfaces/managedCCFOperations.js.map +0 -1
  366. package/dist/esm/operationsInterfaces/operations.d.ts +0 -11
  367. package/dist/esm/operationsInterfaces/operations.d.ts.map +0 -1
  368. package/dist/esm/operationsInterfaces/operations.js +0 -9
  369. package/dist/esm/operationsInterfaces/operations.js.map +0 -1
  370. package/dist/esm/pagingHelper.d.ts +0 -13
  371. package/dist/esm/pagingHelper.d.ts.map +0 -1
  372. package/dist/esm/pagingHelper.js +0 -32
  373. package/dist/esm/pagingHelper.js.map +0 -1
  374. package/dist/react-native/confidentialLedgerClient.d.ts +0 -28
  375. package/dist/react-native/confidentialLedgerClient.d.ts.map +0 -1
  376. package/dist/react-native/confidentialLedgerClient.js +0 -129
  377. package/dist/react-native/confidentialLedgerClient.js.map +0 -1
  378. package/dist/react-native/index.d.ts +0 -5
  379. package/dist/react-native/index.d.ts.map +0 -1
  380. package/dist/react-native/index.js +0 -13
  381. package/dist/react-native/index.js.map +0 -1
  382. package/dist/react-native/lroImpl.d.ts +0 -11
  383. package/dist/react-native/lroImpl.d.ts.map +0 -1
  384. package/dist/react-native/lroImpl.js +0 -21
  385. package/dist/react-native/lroImpl.js.map +0 -1
  386. package/dist/react-native/models/index.d.ts +0 -725
  387. package/dist/react-native/models/index.d.ts.map +0 -1
  388. package/dist/react-native/models/index.js +0 -114
  389. package/dist/react-native/models/index.js.map +0 -1
  390. package/dist/react-native/models/mappers.d.ts +0 -32
  391. package/dist/react-native/models/mappers.d.ts.map +0 -1
  392. package/dist/react-native/models/mappers.js +0 -885
  393. package/dist/react-native/models/mappers.js.map +0 -1
  394. package/dist/react-native/models/parameters.d.ts +0 -19
  395. package/dist/react-native/models/parameters.d.ts.map +0 -1
  396. package/dist/react-native/models/parameters.js +0 -154
  397. package/dist/react-native/models/parameters.js.map +0 -1
  398. package/dist/react-native/operations/index.d.ts +0 -4
  399. package/dist/react-native/operations/index.d.ts.map +0 -1
  400. package/dist/react-native/operations/index.js +0 -11
  401. package/dist/react-native/operations/index.js.map +0 -1
  402. package/dist/react-native/operations/ledger.d.ts +0 -139
  403. package/dist/react-native/operations/ledger.d.ts.map +0 -1
  404. package/dist/react-native/operations/ledger.js +0 -702
  405. package/dist/react-native/operations/ledger.js.map +0 -1
  406. package/dist/react-native/operations/managedCCFOperations.d.ts +0 -139
  407. package/dist/react-native/operations/managedCCFOperations.d.ts.map +0 -1
  408. package/dist/react-native/operations/managedCCFOperations.js +0 -702
  409. package/dist/react-native/operations/managedCCFOperations.js.map +0 -1
  410. package/dist/react-native/operations/operations.d.ts +0 -32
  411. package/dist/react-native/operations/operations.d.ts.map +0 -1
  412. package/dist/react-native/operations/operations.js +0 -133
  413. package/dist/react-native/operations/operations.js.map +0 -1
  414. package/dist/react-native/operationsInterfaces/index.d.ts +0 -4
  415. package/dist/react-native/operationsInterfaces/index.d.ts.map +0 -1
  416. package/dist/react-native/operationsInterfaces/index.js +0 -11
  417. package/dist/react-native/operationsInterfaces/index.js.map +0 -1
  418. package/dist/react-native/operationsInterfaces/ledger.d.ts +0 -103
  419. package/dist/react-native/operationsInterfaces/ledger.d.ts.map +0 -1
  420. package/dist/react-native/operationsInterfaces/ledger.js +0 -9
  421. package/dist/react-native/operationsInterfaces/ledger.js.map +0 -1
  422. package/dist/react-native/operationsInterfaces/managedCCFOperations.d.ts +0 -103
  423. package/dist/react-native/operationsInterfaces/managedCCFOperations.d.ts.map +0 -1
  424. package/dist/react-native/operationsInterfaces/managedCCFOperations.js +0 -9
  425. package/dist/react-native/operationsInterfaces/managedCCFOperations.js.map +0 -1
  426. package/dist/react-native/operationsInterfaces/operations.d.ts +0 -11
  427. package/dist/react-native/operationsInterfaces/operations.d.ts.map +0 -1
  428. package/dist/react-native/operationsInterfaces/operations.js +0 -9
  429. package/dist/react-native/operationsInterfaces/operations.js.map +0 -1
  430. package/dist/react-native/package.json +0 -3
  431. package/dist/react-native/pagingHelper.d.ts +0 -13
  432. package/dist/react-native/pagingHelper.d.ts.map +0 -1
  433. package/dist/react-native/pagingHelper.js +0 -32
  434. package/dist/react-native/pagingHelper.js.map +0 -1
  435. package/review/arm-confidentialledger.api.md +0 -580
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cloudSettingHelpers.js","sourceRoot":"","sources":["../../../src/static-helpers/cloudSettingHelpers.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC;;;GAGG;AACH,MAAM,CAAN,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,qEAAqE;IACrE,wDAAyC,CAAA;IACzC,wBAAwB;IACxB,sDAAuC,CAAA;IACvC,gCAAgC;IAChC,0DAA2C,CAAA;AAC7C,CAAC,EAPW,WAAW,KAAX,WAAW,QAOtB;AAKD;;;;;GAKG;AACH,MAAM,UAAU,cAAc,CAAC,YAAmC;IAChE,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;QAC/B,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,cAAc,GAA6C;QAC/D,iBAAiB,EAAE,sCAAsC;QACzD,mBAAmB,EAAE,uCAAuC;QAC5D,kBAAkB,EAAE,+BAA+B;KACpD,CAAC;IACF,IAAI,YAAY,IAAI,cAAc,EAAE,CAAC;QACnC,OAAO,cAAc,CAAC,YAAY,CAAC,CAAC;IACtC,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,KAAK,CACb,0BAA0B,YAAY,6DAA6D,CACpG,CAAC;IACJ,CAAC;AACH,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * An enum to describe Azure Cloud environments.\n * @enum {string}\n */\nexport enum AzureClouds {\n /** Azure public cloud, which is the default cloud for Azure SDKs. */\n AZURE_PUBLIC_CLOUD = \"AZURE_PUBLIC_CLOUD\",\n /** Azure China cloud */\n AZURE_CHINA_CLOUD = \"AZURE_CHINA_CLOUD\",\n /** Azure US government cloud */\n AZURE_US_GOVERNMENT = \"AZURE_US_GOVERNMENT\",\n}\n\n/** The supported values for cloud setting as a string literal type */\nexport type AzureSupportedClouds = `${AzureClouds}`;\n\n/**\n * Gets the Azure Resource Manager endpoint URL for the specified cloud setting.\n * @param cloudSetting - The Azure cloud environment setting. Use one of the AzureClouds enum values.\n * @returns The ARM endpoint URL for the specified cloud, or undefined if cloudSetting is undefined.\n * @throws {Error} Throws an error if an unknown cloud setting is provided.\n */\nexport function getArmEndpoint(cloudSetting?: AzureSupportedClouds): string | undefined {\n if (cloudSetting === undefined) {\n return undefined;\n }\n const cloudEndpoints: Record<keyof typeof AzureClouds, string> = {\n AZURE_CHINA_CLOUD: \"https://management.chinacloudapi.cn/\",\n AZURE_US_GOVERNMENT: \"https://management.usgovcloudapi.net/\",\n AZURE_PUBLIC_CLOUD: \"https://management.azure.com/\",\n };\n if (cloudSetting in cloudEndpoints) {\n return cloudEndpoints[cloudSetting];\n } else {\n throw new Error(\n `Unknown cloud setting: ${cloudSetting}. Please refer to the enum AzureClouds for possible values.`,\n );\n }\n}\n"]}
@@ -0,0 +1,74 @@
1
+ import { Client, PathUncheckedResponse } from "@azure-rest/core-client";
2
+ /**
3
+ * Options for the byPage method
4
+ */
5
+ export interface PageSettings {
6
+ /**
7
+ * A reference to a specific page to start iterating from.
8
+ */
9
+ continuationToken?: string;
10
+ }
11
+ /**
12
+ * An interface that describes a page of results.
13
+ */
14
+ export type ContinuablePage<TElement, TPage = TElement[]> = TPage & {
15
+ /**
16
+ * The token that keeps track of where to continue the iterator
17
+ */
18
+ continuationToken?: string;
19
+ };
20
+ /**
21
+ * An interface that allows async iterable iteration both to completion and by page.
22
+ */
23
+ export interface PagedAsyncIterableIterator<TElement, TPage = TElement[], TPageSettings extends PageSettings = PageSettings> {
24
+ /**
25
+ * The next method, part of the iteration protocol
26
+ */
27
+ next(): Promise<IteratorResult<TElement>>;
28
+ /**
29
+ * The connection to the async iterator, part of the iteration protocol
30
+ */
31
+ [Symbol.asyncIterator](): PagedAsyncIterableIterator<TElement, TPage, TPageSettings>;
32
+ /**
33
+ * Return an AsyncIterableIterator that works a page at a time
34
+ */
35
+ byPage: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;
36
+ }
37
+ /**
38
+ * An interface that describes how to communicate with the service.
39
+ */
40
+ export interface PagedResult<TElement, TPage = TElement[], TPageSettings extends PageSettings = PageSettings> {
41
+ /**
42
+ * Link to the first page of results.
43
+ */
44
+ firstPageLink?: string;
45
+ /**
46
+ * A method that returns a page of results.
47
+ */
48
+ getPage: (pageLink?: string) => Promise<{
49
+ page: TPage;
50
+ nextPageLink?: string;
51
+ } | undefined>;
52
+ /**
53
+ * a function to implement the `byPage` method on the paged async iterator.
54
+ */
55
+ byPage?: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;
56
+ /**
57
+ * A function to extract elements from a page.
58
+ */
59
+ toElements?: (page: TPage) => TElement[];
60
+ }
61
+ /**
62
+ * Options for the paging helper
63
+ */
64
+ export interface BuildPagedAsyncIteratorOptions {
65
+ itemName?: string;
66
+ nextLinkName?: string;
67
+ nextLinkMethod?: "GET" | "POST";
68
+ apiVersion?: string;
69
+ }
70
+ /**
71
+ * Helper to paginate results in a generic way and return a PagedAsyncIterableIterator
72
+ */
73
+ export declare function buildPagedAsyncIterator<TElement, TPage = TElement[], TPageSettings extends PageSettings = PageSettings, TResponse extends PathUncheckedResponse = PathUncheckedResponse>(client: Client, getInitialResponse: () => PromiseLike<TResponse>, processResponseBody: (result: TResponse) => PromiseLike<unknown>, expectedStatuses: string[], options?: BuildPagedAsyncIteratorOptions): PagedAsyncIterableIterator<TElement, TPage, TPageSettings>;
74
+ //# sourceMappingURL=pagingHelpers.d.ts.map
@@ -0,0 +1,143 @@
1
+ // Copyright (c) Microsoft Corporation.
2
+ // Licensed under the MIT License.
3
+ import { createRestError } from "@azure-rest/core-client";
4
+ import { RestError } from "@azure/core-rest-pipeline";
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 pagedResult = {
14
+ getPage: async (pageLink) => {
15
+ let result;
16
+ if (pageLink === undefined) {
17
+ result = await getInitialResponse();
18
+ }
19
+ else {
20
+ const resolvedPageLink = apiVersion ? addApiVersionToUrl(pageLink, apiVersion) : pageLink;
21
+ result =
22
+ nextLinkMethod === "POST"
23
+ ? await client.pathUnchecked(resolvedPageLink).post()
24
+ : await client.pathUnchecked(resolvedPageLink).get();
25
+ }
26
+ checkPagingRequest(result, expectedStatuses);
27
+ const results = await processResponseBody(result);
28
+ const nextLink = getNextLink(results, nextLinkName);
29
+ const values = getElements(results, itemName);
30
+ return {
31
+ page: values,
32
+ nextPageLink: nextLink,
33
+ };
34
+ },
35
+ byPage: (settings) => {
36
+ const { continuationToken } = settings ?? {};
37
+ return getPageAsyncIterator(pagedResult, {
38
+ pageLink: continuationToken,
39
+ });
40
+ },
41
+ };
42
+ return getPagedAsyncIterator(pagedResult);
43
+ }
44
+ /**
45
+ * returns an async iterator that iterates over results. It also has a `byPage`
46
+ * method that returns pages of items at once.
47
+ *
48
+ * @param pagedResult - an object that specifies how to get pages.
49
+ * @returns a paged async iterator that iterates over results.
50
+ */
51
+ function getPagedAsyncIterator(pagedResult) {
52
+ const iter = getItemAsyncIterator(pagedResult);
53
+ return {
54
+ next() {
55
+ return iter.next();
56
+ },
57
+ [Symbol.asyncIterator]() {
58
+ return this;
59
+ },
60
+ byPage: pagedResult?.byPage ??
61
+ ((settings) => {
62
+ const { continuationToken } = settings ?? {};
63
+ return getPageAsyncIterator(pagedResult, {
64
+ pageLink: continuationToken,
65
+ });
66
+ }),
67
+ };
68
+ }
69
+ async function* getItemAsyncIterator(pagedResult) {
70
+ const pages = getPageAsyncIterator(pagedResult);
71
+ for await (const page of pages) {
72
+ yield* page;
73
+ }
74
+ }
75
+ async function* getPageAsyncIterator(pagedResult, options = {}) {
76
+ const { pageLink } = options;
77
+ let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);
78
+ if (!response) {
79
+ return;
80
+ }
81
+ let result = response.page;
82
+ result.continuationToken = response.nextPageLink;
83
+ yield result;
84
+ while (response.nextPageLink) {
85
+ response = await pagedResult.getPage(response.nextPageLink);
86
+ if (!response) {
87
+ return;
88
+ }
89
+ result = response.page;
90
+ result.continuationToken = response.nextPageLink;
91
+ yield result;
92
+ }
93
+ }
94
+ /**
95
+ * Gets for the value of nextLink in the body
96
+ */
97
+ function getNextLink(body, nextLinkName) {
98
+ if (!nextLinkName) {
99
+ return undefined;
100
+ }
101
+ const nextLink = body[nextLinkName];
102
+ if (typeof nextLink !== "string" && typeof nextLink !== "undefined" && nextLink !== null) {
103
+ throw new RestError(`Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`);
104
+ }
105
+ if (nextLink === null) {
106
+ return undefined;
107
+ }
108
+ return nextLink;
109
+ }
110
+ /**
111
+ * Gets the elements of the current request in the body.
112
+ */
113
+ function getElements(body, itemName) {
114
+ const value = body[itemName];
115
+ if (!Array.isArray(value)) {
116
+ throw new RestError(`Couldn't paginate response\n Body doesn't contain an array property with name: ${itemName}`);
117
+ }
118
+ return value ?? [];
119
+ }
120
+ /**
121
+ * Checks if a request failed
122
+ */
123
+ function checkPagingRequest(response, expectedStatuses) {
124
+ if (!expectedStatuses.includes(response.status)) {
125
+ throw createRestError(`Pagination failed with unexpected statusCode ${response.status}`, response);
126
+ }
127
+ }
128
+ /**
129
+ * Adds the api-version query parameter on a URL if it's not present.
130
+ * @param url - the URL to modify
131
+ * @param apiVersion - the API version to set
132
+ * @returns - the URL with the api-version query parameter set
133
+ */
134
+ function addApiVersionToUrl(url, apiVersion) {
135
+ // The base URL is only used for parsing and won't appear in the returned URL
136
+ const urlObj = new URL(url, "https://microsoft.com");
137
+ if (!urlObj.searchParams.get("api-version")) {
138
+ // Append one if there is no apiVersion
139
+ return `${url}${urlObj.search ? "&" : "?"}api-version=${apiVersion}`;
140
+ }
141
+ return url;
142
+ }
143
+ //# sourceMappingURL=pagingHelpers.js.map
@@ -0,0 +1 @@
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 { Client, createRestError, PathUncheckedResponse } from \"@azure-rest/core-client\";\nimport { RestError } from \"@azure/core-rest-pipeline\";\n\n/**\n * Options for the byPage method\n */\nexport interface PageSettings {\n /**\n * A reference to a specific page to start iterating from.\n */\n continuationToken?: string;\n}\n\n/**\n * An interface that describes a page of results.\n */\nexport type ContinuablePage<TElement, TPage = TElement[]> = TPage & {\n /**\n * The token that keeps track of where to continue the iterator\n */\n continuationToken?: string;\n};\n\n/**\n * An interface that allows async iterable iteration both to completion and by page.\n */\nexport interface PagedAsyncIterableIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n> {\n /**\n * The next method, part of the iteration protocol\n */\n next(): Promise<IteratorResult<TElement>>;\n /**\n * The connection to the async iterator, part of the iteration protocol\n */\n [Symbol.asyncIterator](): PagedAsyncIterableIterator<TElement, TPage, TPageSettings>;\n /**\n * Return an AsyncIterableIterator that works a page at a time\n */\n byPage: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;\n}\n\n/**\n * An interface that describes how to communicate with the service.\n */\nexport interface PagedResult<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n> {\n /**\n * Link to the first page of results.\n */\n firstPageLink?: string;\n /**\n * A method that returns a page of results.\n */\n getPage: (pageLink?: string) => Promise<{ page: TPage; nextPageLink?: string } | undefined>;\n /**\n * a function to implement the `byPage` method on the paged async iterator.\n */\n byPage?: (settings?: TPageSettings) => AsyncIterableIterator<ContinuablePage<TElement, TPage>>;\n\n /**\n * A function to extract elements from a page.\n */\n toElements?: (page: TPage) => TElement[];\n}\n\n/**\n * Options for the paging helper\n */\nexport interface BuildPagedAsyncIteratorOptions {\n itemName?: string;\n nextLinkName?: string;\n nextLinkMethod?: \"GET\" | \"POST\";\n apiVersion?: string;\n}\n\n/**\n * Helper to paginate results in a generic way and return a PagedAsyncIterableIterator\n */\nexport function buildPagedAsyncIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n TResponse extends PathUncheckedResponse = PathUncheckedResponse,\n>(\n client: Client,\n getInitialResponse: () => PromiseLike<TResponse>,\n processResponseBody: (result: TResponse) => PromiseLike<unknown>,\n expectedStatuses: string[],\n options: BuildPagedAsyncIteratorOptions = {},\n): PagedAsyncIterableIterator<TElement, TPage, TPageSettings> {\n const itemName = options.itemName ?? \"value\";\n const nextLinkName = options.nextLinkName ?? \"nextLink\";\n const nextLinkMethod = options.nextLinkMethod ?? \"GET\";\n const apiVersion = options.apiVersion;\n const pagedResult: PagedResult<TElement, TPage, TPageSettings> = {\n getPage: async (pageLink?: string) => {\n let result;\n if (pageLink === undefined) {\n result = await getInitialResponse();\n } else {\n const resolvedPageLink = apiVersion ? addApiVersionToUrl(pageLink, apiVersion) : pageLink;\n result =\n nextLinkMethod === \"POST\"\n ? await client.pathUnchecked(resolvedPageLink).post()\n : await client.pathUnchecked(resolvedPageLink).get();\n }\n checkPagingRequest(result, expectedStatuses);\n const results = await processResponseBody(result as TResponse);\n const nextLink = getNextLink(results, nextLinkName);\n const values = getElements<TElement>(results, itemName) as TPage;\n return {\n page: values,\n nextPageLink: nextLink,\n };\n },\n byPage: (settings?: TPageSettings) => {\n const { continuationToken } = settings ?? {};\n return getPageAsyncIterator(pagedResult, {\n pageLink: continuationToken,\n });\n },\n };\n return getPagedAsyncIterator(pagedResult);\n}\n\n/**\n * returns an async iterator that iterates over results. It also has a `byPage`\n * method that returns pages of items at once.\n *\n * @param pagedResult - an object that specifies how to get pages.\n * @returns a paged async iterator that iterates over results.\n */\n\nfunction getPagedAsyncIterator<\n TElement,\n TPage = TElement[],\n TPageSettings extends PageSettings = PageSettings,\n>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n): PagedAsyncIterableIterator<TElement, TPage, TPageSettings> {\n const iter = getItemAsyncIterator<TElement, TPage, TPageSettings>(pagedResult);\n return {\n next() {\n return iter.next();\n },\n [Symbol.asyncIterator]() {\n return this;\n },\n byPage:\n pagedResult?.byPage ??\n ((settings?: TPageSettings) => {\n const { continuationToken } = settings ?? {};\n return getPageAsyncIterator(pagedResult, {\n pageLink: continuationToken,\n });\n }),\n };\n}\n\nasync function* getItemAsyncIterator<TElement, TPage, TPageSettings extends PageSettings>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n): AsyncIterableIterator<TElement> {\n const pages = getPageAsyncIterator(pagedResult);\n for await (const page of pages) {\n yield* page as unknown as TElement[];\n }\n}\n\nasync function* getPageAsyncIterator<TElement, TPage, TPageSettings extends PageSettings>(\n pagedResult: PagedResult<TElement, TPage, TPageSettings>,\n options: {\n pageLink?: string;\n } = {},\n): AsyncIterableIterator<ContinuablePage<TElement, TPage>> {\n const { pageLink } = options;\n let response = await pagedResult.getPage(pageLink ?? pagedResult.firstPageLink);\n if (!response) {\n return;\n }\n let result = response.page as ContinuablePage<TElement, TPage>;\n result.continuationToken = response.nextPageLink;\n yield result;\n while (response.nextPageLink) {\n response = await pagedResult.getPage(response.nextPageLink);\n if (!response) {\n return;\n }\n result = response.page as ContinuablePage<TElement, TPage>;\n result.continuationToken = response.nextPageLink;\n yield result;\n }\n}\n\n/**\n * Gets for the value of nextLink in the body\n */\nfunction getNextLink(body: unknown, nextLinkName?: string): string | undefined {\n if (!nextLinkName) {\n return undefined;\n }\n\n const nextLink = (body as Record<string, unknown>)[nextLinkName];\n\n if (typeof nextLink !== \"string\" && typeof nextLink !== \"undefined\" && nextLink !== null) {\n throw new RestError(\n `Body Property ${nextLinkName} should be a string or undefined or null but got ${typeof nextLink}`,\n );\n }\n\n if (nextLink === null) {\n return undefined;\n }\n\n return nextLink;\n}\n\n/**\n * Gets the elements of the current request in the body.\n */\nfunction getElements<T = unknown>(body: unknown, itemName: string): T[] {\n const value = (body as Record<string, unknown>)[itemName] as T[];\n if (!Array.isArray(value)) {\n throw new RestError(\n `Couldn't paginate response\\n Body doesn't contain an array property with name: ${itemName}`,\n );\n }\n\n return value ?? [];\n}\n\n/**\n * Checks if a request failed\n */\nfunction checkPagingRequest(response: PathUncheckedResponse, expectedStatuses: string[]): void {\n if (!expectedStatuses.includes(response.status)) {\n throw createRestError(\n `Pagination failed with unexpected statusCode ${response.status}`,\n response,\n );\n }\n}\n\n/**\n * Adds the api-version query parameter on a URL if it's not present.\n * @param url - the URL to modify\n * @param apiVersion - the API version to set\n * @returns - the URL with the api-version query parameter set\n */\nfunction addApiVersionToUrl(url: string, apiVersion: string): string {\n // The base URL is only used for parsing and won't appear in the returned URL\n const urlObj = new URL(url, \"https://microsoft.com\");\n if (!urlObj.searchParams.get(\"api-version\")) {\n // Append one if there is no apiVersion\n return `${url}${urlObj.search ? \"&\" : \"?\"}api-version=${apiVersion}`;\n }\n return url;\n}\n"]}
@@ -0,0 +1,34 @@
1
+ import { PollerLike, OperationState, ResourceLocationConfig } from "@azure/core-lro";
2
+ import { Client, PathUncheckedResponse } from "@azure-rest/core-client";
3
+ import { AbortSignalLike } from "@azure/abort-controller";
4
+ export interface GetLongRunningPollerOptions<TResponse> {
5
+ /** Delay to wait until next poll, in milliseconds. */
6
+ updateIntervalInMs?: number;
7
+ /**
8
+ * The signal which can be used to abort requests.
9
+ */
10
+ abortSignal?: AbortSignalLike;
11
+ /**
12
+ * The potential location of the result of the LRO if specified by the LRO extension in the swagger.
13
+ */
14
+ resourceLocationConfig?: ResourceLocationConfig;
15
+ /**
16
+ * The original url of the LRO
17
+ * Should not be null when restoreFrom is set
18
+ */
19
+ initialRequestUrl?: string;
20
+ /**
21
+ * A serialized poller which can be used to resume an existing paused Long-Running-Operation.
22
+ */
23
+ restoreFrom?: string;
24
+ /**
25
+ * The function to get the initial response
26
+ */
27
+ getInitialResponse?: () => PromiseLike<TResponse>;
28
+ /**
29
+ * The api-version of the LRO
30
+ */
31
+ apiVersion?: string;
32
+ }
33
+ export declare function getLongRunningPoller<TResponse extends PathUncheckedResponse, TResult = void>(client: Client, processResponseBody: (result: TResponse) => Promise<TResult>, expectedStatuses: string[], options: GetLongRunningPollerOptions<TResponse>): PollerLike<OperationState<TResult>, TResult>;
34
+ //# sourceMappingURL=pollingHelpers.d.ts.map
@@ -0,0 +1,95 @@
1
+ // Copyright (c) Microsoft Corporation.
2
+ // Licensed under the MIT License.
3
+ import { createHttpPoller, } from "@azure/core-lro";
4
+ import { createRestError } from "@azure-rest/core-client";
5
+ export function getLongRunningPoller(client, processResponseBody, expectedStatuses, options) {
6
+ const { restoreFrom, getInitialResponse, apiVersion } = options;
7
+ if (!restoreFrom && !getInitialResponse) {
8
+ throw new Error("Either restoreFrom or getInitialResponse must be specified");
9
+ }
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);
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.pathUnchecked(pollingPath).get({ abortSignal });
44
+ }
45
+ finally {
46
+ options.abortSignal?.removeEventListener("abort", abortListener);
47
+ pollOptions?.abortSignal?.removeEventListener("abort", abortListener);
48
+ }
49
+ return getLroResponse(response, expectedStatuses);
50
+ },
51
+ };
52
+ return createHttpPoller(poller, {
53
+ intervalInMs: options?.updateIntervalInMs,
54
+ resourceLocationConfig: options?.resourceLocationConfig,
55
+ restoreFrom: options?.restoreFrom,
56
+ processResult: (result) => {
57
+ return processResponseBody(result);
58
+ },
59
+ });
60
+ }
61
+ /**
62
+ * Converts a Rest Client response to a response that the LRO implementation understands
63
+ * @param response - a rest client http response
64
+ * @param deserializeFn - deserialize function to convert Rest response to modular output
65
+ * @returns - An LRO response that the LRO implementation understands
66
+ */
67
+ function getLroResponse(response, expectedStatuses) {
68
+ if (!expectedStatuses.includes(response.status)) {
69
+ throw createRestError(response);
70
+ }
71
+ return {
72
+ flatResponse: response,
73
+ rawResponse: {
74
+ ...response,
75
+ statusCode: Number.parseInt(response.status),
76
+ body: response.body,
77
+ },
78
+ };
79
+ }
80
+ /**
81
+ * Adds the api-version query parameter on a URL if it's not present.
82
+ * @param url - the URL to modify
83
+ * @param apiVersion - the API version to set
84
+ * @returns - the URL with the api-version query parameter set
85
+ */
86
+ function addApiVersionToUrl(url, apiVersion) {
87
+ // The base URL is only used for parsing and won't appear in the returned URL
88
+ const urlObj = new URL(url, "https://microsoft.com");
89
+ if (!urlObj.searchParams.get("api-version")) {
90
+ // Append one if there is no apiVersion
91
+ return `${url}${urlObj.search ? "&" : "?"}api-version=${apiVersion}`;
92
+ }
93
+ return url;
94
+ }
95
+ //# sourceMappingURL=pollingHelpers.js.map
@@ -0,0 +1 @@
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 {\n PollerLike,\n OperationState,\n ResourceLocationConfig,\n RunningOperation,\n createHttpPoller,\n OperationResponse,\n} from \"@azure/core-lro\";\n\nimport { Client, PathUncheckedResponse, createRestError } from \"@azure-rest/core-client\";\nimport { AbortSignalLike } from \"@azure/abort-controller\";\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 function to get the initial response\n */\n getInitialResponse?: () => PromiseLike<TResponse>;\n /**\n * The api-version of the LRO\n */\n apiVersion?: string;\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}${urlObj.search ? \"&\" : \"?\"}api-version=${apiVersion}`;\n }\n return url;\n}\n"]}
@@ -0,0 +1,73 @@
1
+ import { PollerLike, OperationState, CancelOnProgress } from "@azure/core-lro";
2
+ import { AbortSignalLike } from "@azure/abort-controller";
3
+ /**
4
+ * A simple poller that can be used to poll a long running operation.
5
+ */
6
+ export interface SimplePollerLike<TState extends OperationState<TResult>, TResult> {
7
+ /**
8
+ * Returns true if the poller has finished polling.
9
+ */
10
+ isDone(): boolean;
11
+ /**
12
+ * Returns the state of the operation.
13
+ */
14
+ getOperationState(): TState;
15
+ /**
16
+ * Returns the result value of the operation,
17
+ * regardless of the state of the poller.
18
+ * It can return undefined or an incomplete form of the final TResult value
19
+ * depending on the implementation.
20
+ */
21
+ getResult(): TResult | undefined;
22
+ /**
23
+ * Returns a promise that will resolve once a single polling request finishes.
24
+ * It does this by calling the update method of the Poller's operation.
25
+ */
26
+ poll(options?: {
27
+ abortSignal?: AbortSignalLike;
28
+ }): Promise<TState>;
29
+ /**
30
+ * Returns a promise that will resolve once the underlying operation is completed.
31
+ */
32
+ pollUntilDone(pollOptions?: {
33
+ abortSignal?: AbortSignalLike;
34
+ }): Promise<TResult>;
35
+ /**
36
+ * Invokes the provided callback after each polling is completed,
37
+ * sending the current state of the poller's operation.
38
+ *
39
+ * It returns a method that can be used to stop receiving updates on the given callback function.
40
+ */
41
+ onProgress(callback: (state: TState) => void): CancelOnProgress;
42
+ /**
43
+ * Returns a promise that could be used for serialized version of the poller's operation
44
+ * by invoking the operation's serialize method.
45
+ */
46
+ serialize(): Promise<string>;
47
+ /**
48
+ * Wait the poller to be submitted.
49
+ */
50
+ submitted(): Promise<void>;
51
+ /**
52
+ * Returns a string representation of the poller's operation. Similar to serialize but returns a string.
53
+ * @deprecated Use serialize() instead.
54
+ */
55
+ toString(): string;
56
+ /**
57
+ * Stops the poller from continuing to poll. Please note this will only stop the client-side polling
58
+ * @deprecated Use abortSignal to stop polling instead.
59
+ */
60
+ stopPolling(): void;
61
+ /**
62
+ * Returns true if the poller is stopped.
63
+ * @deprecated Use abortSignal status to track this instead.
64
+ */
65
+ isStopped(): boolean;
66
+ }
67
+ /**
68
+ * Create the deprecated SimplePollerLike from PollerLike
69
+ * @param poller PollerLike to convert
70
+ * @returns SimplePollerLike
71
+ */
72
+ export declare function getSimplePoller<TResult>(poller: PollerLike<OperationState<TResult>, TResult>): SimplePollerLike<OperationState<TResult>, TResult>;
73
+ //# sourceMappingURL=simplePollerHelpers.d.ts.map
@@ -0,0 +1,44 @@
1
+ // Copyright (c) Microsoft Corporation.
2
+ // Licensed under the MIT License.
3
+ /**
4
+ * Create the deprecated SimplePollerLike from PollerLike
5
+ * @param poller PollerLike to convert
6
+ * @returns SimplePollerLike
7
+ */
8
+ export function getSimplePoller(poller) {
9
+ const simplePoller = {
10
+ isDone() {
11
+ return poller.isDone;
12
+ },
13
+ isStopped() {
14
+ throw new Error("isStopped is deprecated. Use abortSignal status to track this instead.");
15
+ },
16
+ getOperationState() {
17
+ if (!poller.operationState) {
18
+ throw new Error("Operation state is not available. The poller may not have been started and you could await submitted() before calling getOperationState().");
19
+ }
20
+ return poller.operationState;
21
+ },
22
+ getResult() {
23
+ return poller.result;
24
+ },
25
+ toString() {
26
+ if (!poller.operationState) {
27
+ throw new Error("Operation state is not available. The poller may not have been started and you could await submitted() before calling getOperationState().");
28
+ }
29
+ return JSON.stringify({
30
+ state: poller.operationState,
31
+ });
32
+ },
33
+ stopPolling() {
34
+ throw new Error("stopPolling is deprecated. Use abortSignal to stop polling instead.");
35
+ },
36
+ onProgress: poller.onProgress,
37
+ poll: poller.poll,
38
+ pollUntilDone: poller.pollUntilDone,
39
+ serialize: poller.serialize,
40
+ submitted: poller.submitted,
41
+ };
42
+ return simplePoller;
43
+ }
44
+ //# sourceMappingURL=simplePollerHelpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"simplePollerHelpers.js","sourceRoot":"","sources":["../../../src/static-helpers/simplePollerHelpers.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAuElC;;;;GAIG;AACH,MAAM,UAAU,eAAe,CAC7B,MAAoD;IAEpD,MAAM,YAAY,GAAuD;QACvE,MAAM;YACJ,OAAO,MAAM,CAAC,MAAM,CAAC;QACvB,CAAC;QACD,SAAS;YACP,MAAM,IAAI,KAAK,CAAC,wEAAwE,CAAC,CAAC;QAC5F,CAAC;QACD,iBAAiB;YACf,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;gBAC3B,MAAM,IAAI,KAAK,CACb,4IAA4I,CAC7I,CAAC;YACJ,CAAC;YACD,OAAO,MAAM,CAAC,cAAc,CAAC;QAC/B,CAAC;QACD,SAAS;YACP,OAAO,MAAM,CAAC,MAAM,CAAC;QACvB,CAAC;QACD,QAAQ;YACN,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;gBAC3B,MAAM,IAAI,KAAK,CACb,4IAA4I,CAC7I,CAAC;YACJ,CAAC;YACD,OAAO,IAAI,CAAC,SAAS,CAAC;gBACpB,KAAK,EAAE,MAAM,CAAC,cAAc;aAC7B,CAAC,CAAC;QACL,CAAC;QACD,WAAW;YACT,MAAM,IAAI,KAAK,CAAC,qEAAqE,CAAC,CAAC;QACzF,CAAC;QACD,UAAU,EAAE,MAAM,CAAC,UAAU;QAC7B,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,aAAa,EAAE,MAAM,CAAC,aAAa;QACnC,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,SAAS,EAAE,MAAM,CAAC,SAAS;KAC5B,CAAC;IACF,OAAO,YAAY,CAAC;AACtB,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { PollerLike, OperationState, CancelOnProgress } from \"@azure/core-lro\";\nimport { AbortSignalLike } from \"@azure/abort-controller\";\n\n/**\n * A simple poller that can be used to poll a long running operation.\n */\nexport interface SimplePollerLike<TState extends OperationState<TResult>, TResult> {\n /**\n * Returns true if the poller has finished polling.\n */\n isDone(): boolean;\n /**\n * Returns the state of the operation.\n */\n getOperationState(): TState;\n /**\n * Returns the result value of the operation,\n * regardless of the state of the poller.\n * It can return undefined or an incomplete form of the final TResult value\n * depending on the implementation.\n */\n getResult(): TResult | undefined;\n /**\n * Returns a promise that will resolve once a single polling request finishes.\n * It does this by calling the update method of the Poller's operation.\n */\n poll(options?: { abortSignal?: AbortSignalLike }): Promise<TState>;\n /**\n * Returns a promise that will resolve once the underlying operation is completed.\n */\n pollUntilDone(pollOptions?: { abortSignal?: AbortSignalLike }): Promise<TResult>;\n /**\n * Invokes the provided callback after each polling is completed,\n * sending the current state of the poller's operation.\n *\n * It returns a method that can be used to stop receiving updates on the given callback function.\n */\n onProgress(callback: (state: TState) => void): CancelOnProgress;\n\n /**\n * Returns a promise that could be used for serialized version of the poller's operation\n * by invoking the operation's serialize method.\n */\n serialize(): Promise<string>;\n\n /**\n * Wait the poller to be submitted.\n */\n submitted(): Promise<void>;\n\n /**\n * Returns a string representation of the poller's operation. Similar to serialize but returns a string.\n * @deprecated Use serialize() instead.\n */\n toString(): string;\n\n /**\n * Stops the poller from continuing to poll. Please note this will only stop the client-side polling\n * @deprecated Use abortSignal to stop polling instead.\n */\n stopPolling(): void;\n\n /**\n * Returns true if the poller is stopped.\n * @deprecated Use abortSignal status to track this instead.\n */\n isStopped(): boolean;\n}\n\n/**\n * Create the deprecated SimplePollerLike from PollerLike\n * @param poller PollerLike to convert\n * @returns SimplePollerLike\n */\nexport function getSimplePoller<TResult>(\n poller: PollerLike<OperationState<TResult>, TResult>,\n): SimplePollerLike<OperationState<TResult>, TResult> {\n const simplePoller: SimplePollerLike<OperationState<TResult>, TResult> = {\n isDone() {\n return poller.isDone;\n },\n isStopped() {\n throw new Error(\"isStopped is deprecated. Use abortSignal status to track this instead.\");\n },\n getOperationState() {\n if (!poller.operationState) {\n throw new Error(\n \"Operation state is not available. The poller may not have been started and you could await submitted() before calling getOperationState().\",\n );\n }\n return poller.operationState;\n },\n getResult() {\n return poller.result;\n },\n toString() {\n if (!poller.operationState) {\n throw new Error(\n \"Operation state is not available. The poller may not have been started and you could await submitted() before calling getOperationState().\",\n );\n }\n return JSON.stringify({\n state: poller.operationState,\n });\n },\n stopPolling() {\n throw new Error(\"stopPolling is deprecated. Use abortSignal to stop polling instead.\");\n },\n onProgress: poller.onProgress,\n poll: poller.poll,\n pollUntilDone: poller.pollUntilDone,\n serialize: poller.serialize,\n submitted: poller.submitted,\n };\n return simplePoller;\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export interface UrlTemplateOptions {
2
+ allowReserved?: boolean;
3
+ }
4
+ export declare function expandUrlTemplate(template: string, context: Record<string, any>, option?: UrlTemplateOptions): string;
5
+ //# sourceMappingURL=urlTemplate.d.ts.map