@azure-rest/maps-route 1.0.0-beta.4 → 1.0.0-beta.5

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 (240) hide show
  1. package/LICENSE +4 -4
  2. package/README.md +49 -35
  3. package/dist/browser/generated/clientDefinitions.d.ts +617 -0
  4. package/dist/browser/generated/clientDefinitions.d.ts.map +1 -0
  5. package/dist/browser/generated/clientDefinitions.js +4 -0
  6. package/dist/browser/generated/clientDefinitions.js.map +1 -0
  7. package/dist/browser/generated/index.d.ts +12 -0
  8. package/dist/browser/generated/index.d.ts.map +1 -0
  9. package/dist/browser/generated/index.js +14 -0
  10. package/dist/browser/generated/index.js.map +1 -0
  11. package/dist/browser/generated/isUnexpected.d.ts +7 -0
  12. package/dist/browser/generated/isUnexpected.d.ts.map +1 -0
  13. package/dist/browser/generated/isUnexpected.js +79 -0
  14. package/dist/browser/generated/isUnexpected.js.map +1 -0
  15. package/dist/browser/generated/logger.d.ts +2 -0
  16. package/dist/browser/generated/logger.d.ts.map +1 -0
  17. package/dist/browser/generated/logger.js +5 -0
  18. package/dist/browser/generated/logger.js.map +1 -0
  19. package/dist/browser/generated/mapsRouteClient.d.ts +15 -0
  20. package/dist/browser/generated/mapsRouteClient.d.ts.map +1 -0
  21. package/dist/browser/generated/mapsRouteClient.js +42 -0
  22. package/dist/browser/generated/mapsRouteClient.js.map +1 -0
  23. package/dist/browser/generated/models.d.ts +130 -0
  24. package/dist/browser/generated/models.d.ts.map +1 -0
  25. package/dist/browser/generated/models.js +4 -0
  26. package/dist/browser/generated/models.js.map +1 -0
  27. package/dist/browser/generated/outputModels.d.ts +286 -0
  28. package/dist/browser/generated/outputModels.d.ts.map +1 -0
  29. package/dist/browser/generated/outputModels.js +4 -0
  30. package/dist/browser/generated/outputModels.js.map +1 -0
  31. package/dist/browser/generated/parameters.d.ts +937 -0
  32. package/dist/browser/generated/parameters.d.ts.map +1 -0
  33. package/dist/browser/generated/parameters.js +4 -0
  34. package/dist/browser/generated/parameters.js.map +1 -0
  35. package/dist/browser/generated/pollingHelper.d.ts +76 -0
  36. package/dist/browser/generated/pollingHelper.d.ts.map +1 -0
  37. package/dist/browser/generated/pollingHelper.js +105 -0
  38. package/dist/browser/generated/pollingHelper.js.map +1 -0
  39. package/dist/browser/generated/responses.d.ts +1409 -0
  40. package/dist/browser/generated/responses.d.ts.map +1 -0
  41. package/dist/browser/generated/responses.js +4 -0
  42. package/dist/browser/generated/responses.js.map +1 -0
  43. package/dist/browser/generated/serializeHelper.d.ts +2 -0
  44. package/dist/browser/generated/serializeHelper.d.ts.map +1 -0
  45. package/dist/browser/generated/serializeHelper.js +13 -0
  46. package/dist/browser/generated/serializeHelper.js.map +1 -0
  47. package/dist/browser/helpers.d.ts +18 -0
  48. package/dist/browser/helpers.d.ts.map +1 -0
  49. package/dist/browser/helpers.js.map +1 -0
  50. package/dist/browser/index.d.ts +5 -0
  51. package/dist/browser/index.d.ts.map +1 -0
  52. package/dist/browser/index.js +7 -0
  53. package/dist/browser/index.js.map +1 -0
  54. package/dist/browser/mapsRoute.d.ts +53 -0
  55. package/dist/browser/mapsRoute.d.ts.map +1 -0
  56. package/{dist-esm/src → dist/browser}/mapsRoute.js +1 -1
  57. package/dist/browser/mapsRoute.js.map +1 -0
  58. package/dist/browser/package.json +3 -0
  59. package/dist/commonjs/generated/clientDefinitions.d.ts +617 -0
  60. package/dist/commonjs/generated/clientDefinitions.d.ts.map +1 -0
  61. package/dist/commonjs/generated/clientDefinitions.js +5 -0
  62. package/dist/commonjs/generated/clientDefinitions.js.map +1 -0
  63. package/dist/commonjs/generated/index.d.ts +12 -0
  64. package/dist/commonjs/generated/index.d.ts.map +1 -0
  65. package/dist/commonjs/generated/index.js +17 -0
  66. package/dist/commonjs/generated/index.js.map +1 -0
  67. package/dist/commonjs/generated/isUnexpected.d.ts +7 -0
  68. package/dist/commonjs/generated/isUnexpected.d.ts.map +1 -0
  69. package/dist/commonjs/generated/isUnexpected.js +82 -0
  70. package/dist/commonjs/generated/isUnexpected.js.map +1 -0
  71. package/dist/commonjs/generated/logger.d.ts +2 -0
  72. package/dist/commonjs/generated/logger.d.ts.map +1 -0
  73. package/dist/commonjs/generated/logger.js +8 -0
  74. package/dist/commonjs/generated/logger.js.map +1 -0
  75. package/dist/commonjs/generated/mapsRouteClient.d.ts +15 -0
  76. package/dist/commonjs/generated/mapsRouteClient.d.ts.map +1 -0
  77. package/dist/commonjs/generated/mapsRouteClient.js +45 -0
  78. package/dist/commonjs/generated/mapsRouteClient.js.map +1 -0
  79. package/dist/commonjs/generated/models.d.ts +130 -0
  80. package/dist/commonjs/generated/models.d.ts.map +1 -0
  81. package/dist/commonjs/generated/models.js +5 -0
  82. package/dist/commonjs/generated/models.js.map +1 -0
  83. package/dist/commonjs/generated/outputModels.d.ts +286 -0
  84. package/dist/commonjs/generated/outputModels.d.ts.map +1 -0
  85. package/dist/commonjs/generated/outputModels.js +5 -0
  86. package/dist/commonjs/generated/outputModels.js.map +1 -0
  87. package/dist/commonjs/generated/parameters.d.ts +937 -0
  88. package/dist/commonjs/generated/parameters.d.ts.map +1 -0
  89. package/dist/commonjs/generated/parameters.js +5 -0
  90. package/dist/commonjs/generated/parameters.js.map +1 -0
  91. package/dist/commonjs/generated/pollingHelper.d.ts +76 -0
  92. package/dist/commonjs/generated/pollingHelper.d.ts.map +1 -0
  93. package/dist/commonjs/generated/pollingHelper.js +108 -0
  94. package/dist/commonjs/generated/pollingHelper.js.map +1 -0
  95. package/dist/commonjs/generated/responses.d.ts +1409 -0
  96. package/dist/commonjs/generated/responses.d.ts.map +1 -0
  97. package/dist/commonjs/generated/responses.js +5 -0
  98. package/dist/commonjs/generated/responses.js.map +1 -0
  99. package/dist/commonjs/generated/serializeHelper.d.ts +2 -0
  100. package/dist/commonjs/generated/serializeHelper.d.ts.map +1 -0
  101. package/dist/commonjs/generated/serializeHelper.js +16 -0
  102. package/dist/commonjs/generated/serializeHelper.js.map +1 -0
  103. package/dist/commonjs/helpers.d.ts +18 -0
  104. package/dist/commonjs/helpers.d.ts.map +1 -0
  105. package/dist/commonjs/helpers.js +47 -0
  106. package/dist/commonjs/helpers.js.map +1 -0
  107. package/dist/commonjs/index.d.ts +5 -0
  108. package/dist/commonjs/index.d.ts.map +1 -0
  109. package/dist/commonjs/index.js +10 -0
  110. package/dist/commonjs/index.js.map +1 -0
  111. package/dist/commonjs/mapsRoute.d.ts +53 -0
  112. package/dist/commonjs/mapsRoute.d.ts.map +1 -0
  113. package/dist/commonjs/mapsRoute.js +44 -0
  114. package/dist/commonjs/mapsRoute.js.map +1 -0
  115. package/dist/commonjs/package.json +3 -0
  116. package/dist/commonjs/tsdoc-metadata.json +11 -0
  117. package/dist/esm/generated/clientDefinitions.d.ts +617 -0
  118. package/dist/esm/generated/clientDefinitions.d.ts.map +1 -0
  119. package/dist/esm/generated/clientDefinitions.js +4 -0
  120. package/dist/esm/generated/clientDefinitions.js.map +1 -0
  121. package/dist/esm/generated/index.d.ts +12 -0
  122. package/dist/esm/generated/index.d.ts.map +1 -0
  123. package/dist/esm/generated/index.js +14 -0
  124. package/dist/esm/generated/index.js.map +1 -0
  125. package/dist/esm/generated/isUnexpected.d.ts +7 -0
  126. package/dist/esm/generated/isUnexpected.d.ts.map +1 -0
  127. package/dist/esm/generated/isUnexpected.js +79 -0
  128. package/dist/esm/generated/isUnexpected.js.map +1 -0
  129. package/dist/esm/generated/logger.d.ts +2 -0
  130. package/dist/esm/generated/logger.d.ts.map +1 -0
  131. package/dist/esm/generated/logger.js +5 -0
  132. package/dist/esm/generated/logger.js.map +1 -0
  133. package/dist/esm/generated/mapsRouteClient.d.ts +15 -0
  134. package/dist/esm/generated/mapsRouteClient.d.ts.map +1 -0
  135. package/dist/esm/generated/mapsRouteClient.js +42 -0
  136. package/dist/esm/generated/mapsRouteClient.js.map +1 -0
  137. package/dist/esm/generated/models.d.ts +130 -0
  138. package/dist/esm/generated/models.d.ts.map +1 -0
  139. package/dist/esm/generated/models.js +4 -0
  140. package/dist/esm/generated/models.js.map +1 -0
  141. package/dist/esm/generated/outputModels.d.ts +286 -0
  142. package/dist/esm/generated/outputModels.d.ts.map +1 -0
  143. package/dist/esm/generated/outputModels.js +4 -0
  144. package/dist/esm/generated/outputModels.js.map +1 -0
  145. package/dist/esm/generated/parameters.d.ts +937 -0
  146. package/dist/esm/generated/parameters.d.ts.map +1 -0
  147. package/dist/esm/generated/parameters.js +4 -0
  148. package/dist/esm/generated/parameters.js.map +1 -0
  149. package/dist/esm/generated/pollingHelper.d.ts +76 -0
  150. package/dist/esm/generated/pollingHelper.d.ts.map +1 -0
  151. package/dist/esm/generated/pollingHelper.js +105 -0
  152. package/dist/esm/generated/pollingHelper.js.map +1 -0
  153. package/dist/esm/generated/responses.d.ts +1409 -0
  154. package/dist/esm/generated/responses.d.ts.map +1 -0
  155. package/dist/esm/generated/responses.js +4 -0
  156. package/dist/esm/generated/responses.js.map +1 -0
  157. package/dist/esm/generated/serializeHelper.d.ts +2 -0
  158. package/dist/esm/generated/serializeHelper.d.ts.map +1 -0
  159. package/dist/esm/generated/serializeHelper.js +13 -0
  160. package/dist/esm/generated/serializeHelper.js.map +1 -0
  161. package/dist/esm/helpers.d.ts +18 -0
  162. package/dist/esm/helpers.d.ts.map +1 -0
  163. package/dist/esm/helpers.js +43 -0
  164. package/dist/esm/helpers.js.map +1 -0
  165. package/dist/esm/index.d.ts +5 -0
  166. package/dist/esm/index.d.ts.map +1 -0
  167. package/dist/esm/index.js +7 -0
  168. package/dist/esm/index.js.map +1 -0
  169. package/dist/esm/mapsRoute.d.ts +53 -0
  170. package/dist/esm/mapsRoute.d.ts.map +1 -0
  171. package/dist/esm/mapsRoute.js +40 -0
  172. package/dist/esm/mapsRoute.js.map +1 -0
  173. package/dist/esm/package.json +3 -0
  174. package/dist/react-native/generated/clientDefinitions.d.ts +617 -0
  175. package/dist/react-native/generated/clientDefinitions.d.ts.map +1 -0
  176. package/dist/react-native/generated/clientDefinitions.js +4 -0
  177. package/dist/react-native/generated/clientDefinitions.js.map +1 -0
  178. package/dist/react-native/generated/index.d.ts +12 -0
  179. package/dist/react-native/generated/index.d.ts.map +1 -0
  180. package/dist/react-native/generated/index.js +14 -0
  181. package/dist/react-native/generated/index.js.map +1 -0
  182. package/dist/react-native/generated/isUnexpected.d.ts +7 -0
  183. package/dist/react-native/generated/isUnexpected.d.ts.map +1 -0
  184. package/dist/react-native/generated/isUnexpected.js +79 -0
  185. package/dist/react-native/generated/isUnexpected.js.map +1 -0
  186. package/dist/react-native/generated/logger.d.ts +2 -0
  187. package/dist/react-native/generated/logger.d.ts.map +1 -0
  188. package/dist/react-native/generated/logger.js +5 -0
  189. package/dist/react-native/generated/logger.js.map +1 -0
  190. package/dist/react-native/generated/mapsRouteClient.d.ts +15 -0
  191. package/dist/react-native/generated/mapsRouteClient.d.ts.map +1 -0
  192. package/dist/react-native/generated/mapsRouteClient.js +42 -0
  193. package/dist/react-native/generated/mapsRouteClient.js.map +1 -0
  194. package/dist/react-native/generated/models.d.ts +130 -0
  195. package/dist/react-native/generated/models.d.ts.map +1 -0
  196. package/dist/react-native/generated/models.js +4 -0
  197. package/dist/react-native/generated/models.js.map +1 -0
  198. package/dist/react-native/generated/outputModels.d.ts +286 -0
  199. package/dist/react-native/generated/outputModels.d.ts.map +1 -0
  200. package/dist/react-native/generated/outputModels.js +4 -0
  201. package/dist/react-native/generated/outputModels.js.map +1 -0
  202. package/dist/react-native/generated/parameters.d.ts +937 -0
  203. package/dist/react-native/generated/parameters.d.ts.map +1 -0
  204. package/dist/react-native/generated/parameters.js +4 -0
  205. package/dist/react-native/generated/parameters.js.map +1 -0
  206. package/dist/react-native/generated/pollingHelper.d.ts +76 -0
  207. package/dist/react-native/generated/pollingHelper.d.ts.map +1 -0
  208. package/dist/react-native/generated/pollingHelper.js +105 -0
  209. package/dist/react-native/generated/pollingHelper.js.map +1 -0
  210. package/dist/react-native/generated/responses.d.ts +1409 -0
  211. package/dist/react-native/generated/responses.d.ts.map +1 -0
  212. package/dist/react-native/generated/responses.js +4 -0
  213. package/dist/react-native/generated/responses.js.map +1 -0
  214. package/dist/react-native/generated/serializeHelper.d.ts +2 -0
  215. package/dist/react-native/generated/serializeHelper.d.ts.map +1 -0
  216. package/dist/react-native/generated/serializeHelper.js +13 -0
  217. package/dist/react-native/generated/serializeHelper.js.map +1 -0
  218. package/dist/react-native/helpers.d.ts +18 -0
  219. package/dist/react-native/helpers.d.ts.map +1 -0
  220. package/dist/react-native/helpers.js +43 -0
  221. package/dist/react-native/helpers.js.map +1 -0
  222. package/dist/react-native/index.d.ts +5 -0
  223. package/dist/react-native/index.d.ts.map +1 -0
  224. package/dist/react-native/index.js +7 -0
  225. package/dist/react-native/index.js.map +1 -0
  226. package/dist/react-native/mapsRoute.d.ts +53 -0
  227. package/dist/react-native/mapsRoute.d.ts.map +1 -0
  228. package/dist/react-native/mapsRoute.js +40 -0
  229. package/dist/react-native/mapsRoute.js.map +1 -0
  230. package/dist/react-native/package.json +3 -0
  231. package/package.json +70 -49
  232. package/dist/index.js +0 -340
  233. package/dist/index.js.map +0 -1
  234. package/dist-esm/src/helpers.js.map +0 -1
  235. package/dist-esm/src/index.js +0 -7
  236. package/dist-esm/src/index.js.map +0 -1
  237. package/dist-esm/src/mapsRoute.js.map +0 -1
  238. package/review/maps-route.api.md +0 -934
  239. package/types/maps-route-rest.d.ts +0 -3659
  240. /package/{dist-esm/src → dist/browser}/helpers.js +0 -0
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@azure-rest/maps-route",
3
3
  "sdk-type": "client",
4
4
  "author": "Microsoft Corporation",
5
- "version": "1.0.0-beta.4",
5
+ "version": "1.0.0-beta.5",
6
6
  "description": "A client library for Azure Maps maps-route",
7
7
  "keywords": [
8
8
  "node",
@@ -15,9 +15,9 @@
15
15
  "route"
16
16
  ],
17
17
  "license": "MIT",
18
- "main": "dist/index.js",
19
- "module": "./dist-esm/src/index.js",
20
- "types": "./types/maps-route-rest.d.ts",
18
+ "main": "./dist/commonjs/index.js",
19
+ "module": "./dist/esm/index.js",
20
+ "types": "./dist/commonjs/index.d.ts",
21
21
  "homepage": "https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/maps/maps-route-rest/README.md",
22
22
  "repository": "github:Azure/azure-sdk-for-js",
23
23
  "bugs": {
@@ -25,11 +25,8 @@
25
25
  },
26
26
  "files": [
27
27
  "dist/",
28
- "dist-esm/src/",
29
- "types/maps-route-rest.d.ts",
30
28
  "README.md",
31
- "LICENSE",
32
- "review/*"
29
+ "LICENSE"
33
30
  ],
34
31
  "//sampleConfiguration": {
35
32
  "productName": "Azure Maps Route",
@@ -38,9 +35,8 @@
38
35
  "azure-maps"
39
36
  ],
40
37
  "requiredResources": {
41
- "Azure Maps Resource": "https://docs.microsoft.com/azure/azure-maps/how-to-create-template"
38
+ "Azure Maps Resource": "https://learn.microsoft.com/azure/azure-maps/how-to-create-template"
42
39
  },
43
- "apiRefLink": "https://docs.microsoft.com/javascript/api/@azure-rest/maps-route",
44
40
  "disableDocsMs": true
45
41
  },
46
42
  "//metadata": {
@@ -55,21 +51,21 @@
55
51
  "node": ">=18.0.0"
56
52
  },
57
53
  "scripts": {
58
- "build": "npm run clean && tsc -p . && dev-tool run bundle && dev-tool run vendored mkdirp ./review && dev-tool run extract-api",
59
- "build:browser": "tsc -p . && dev-tool run bundle",
60
- "build:debug": "tsc -p . && dev-tool run bundle && dev-tool run extract-api",
61
- "build:node": "tsc -p . && dev-tool run bundle --browser-test false",
54
+ "build": "npm run clean && dev-tool run build-package && dev-tool run extract-api",
55
+ "build:browser": "dev-tool run build-package && dev-tool run bundle",
56
+ "build:debug": "dev-tool run build-package && dev-tool run bundle && dev-tool run extract-api",
57
+ "build:node": "dev-tool run build-package && dev-tool run bundle --browser-test false",
62
58
  "build:samples": "dev-tool samples publish --force",
63
- "build:test": "tsc -p . && dev-tool run bundle",
59
+ "build:test": "dev-tool run build-package && dev-tool run bundle",
64
60
  "check-format": "dev-tool run vendored prettier --list-different --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.ts\" \"test/**/*.ts\" \"samples-dev/**/*.ts\" \"*.{js,json}\"",
65
61
  "clean": "dev-tool run vendored rimraf --glob dist dist-browser dist-esm test-dist temp types *.tgz *.log",
66
62
  "execute:samples": "dev-tool samples run samples-dev",
67
- "extract-api": "dev-tool run vendored rimraf review && dev-tool run vendored mkdirp ./review && dev-tool run extract-api",
63
+ "extract-api": "dev-tool run vendored rimraf review && dev-tool run extract-api",
68
64
  "format": "dev-tool run vendored prettier --write --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.ts\" \"test/**/*.ts\" \"samples-dev/**/*.ts\" \"*.{js,json}\"",
69
65
  "generate:client": "autorest --typescript swagger/README.md && npm run format",
70
66
  "integration-test": "npm run integration-test:node && npm run integration-test:browser",
71
67
  "integration-test:browser": "dev-tool run test:browser",
72
- "integration-test:node": "dev-tool run test:node-js-input -- --timeout 5000000 'dist-esm/test/**/*.spec.js'",
68
+ "integration-test:node": "dev-tool run test:vitest --esm",
73
69
  "lint": "eslint package.json api-extractor.json src test",
74
70
  "lint:fix": "eslint package.json api-extractor.json src test --fix --fix-type [problem,suggestion]",
75
71
  "pack": "npm pack 2>&1",
@@ -77,52 +73,77 @@
77
73
  "test:browser": "npm run clean && npm run build:test && npm run unit-test:browser",
78
74
  "test:node": "npm run clean && npm run build:test && npm run unit-test:node",
79
75
  "unit-test": "npm run unit-test:node && npm run unit-test:browser",
80
- "unit-test:browser": "dev-tool run test:browser",
81
- "unit-test:node": "dev-tool run test:node-ts-input -- --timeout 1200000 --exclude 'test/**/browser/*.spec.ts' 'test/**/*.spec.ts'",
82
- "update-snippets": "echo skipped"
76
+ "unit-test:browser": "npm run clean && dev-tool run build-package && dev-tool run build-test && dev-tool run test:vitest --browser",
77
+ "unit-test:node": "dev-tool run test:vitest",
78
+ "update-snippets": "dev-tool run update-snippets"
83
79
  },
84
80
  "sideEffects": false,
85
81
  "autoPublish": false,
86
82
  "dependencies": {
87
83
  "@azure-rest/core-client": "^1.0.0",
88
- "@azure/core-auth": "^1.3.0",
84
+ "@azure/abort-controller": "^2.1.2",
85
+ "@azure/core-auth": "^1.9.0",
89
86
  "@azure/core-lro": "^3.1.0",
90
- "@azure/core-rest-pipeline": "^1.8.0",
91
- "@azure/logger": "^1.0.0",
87
+ "@azure/core-rest-pipeline": "^1.19.0",
88
+ "@azure/logger": "^1.1.4",
92
89
  "@azure/maps-common": "1.0.0-beta.2",
93
- "tslib": "^2.4.0",
94
- "@azure/abort-controller": "^2.1.2"
90
+ "tslib": "^2.8.1"
95
91
  },
96
92
  "devDependencies": {
97
- "@azure-tools/test-credential": "^1.0.0",
98
- "@azure-tools/test-recorder": "^3.0.0",
93
+ "@azure-tools/test-credential": "^2.0.0",
94
+ "@azure-tools/test-recorder": "^4.1.0",
95
+ "@azure-tools/test-utils-vitest": "^1.0.0",
99
96
  "@azure/dev-tool": "^1.0.0",
100
97
  "@azure/eslint-plugin-azure-sdk": "^3.0.0",
101
- "@azure/identity": "^4.0.1",
102
- "@types/chai": "^4.2.8",
103
- "@types/mocha": "^10.0.0",
98
+ "@azure/identity": "^4.6.0",
104
99
  "@types/node": "^18.0.0",
100
+ "@vitest/browser": "^3.0.5",
101
+ "@vitest/coverage-istanbul": "^3.0.5",
105
102
  "autorest": "latest",
106
- "chai": "^4.2.0",
107
103
  "dotenv": "^16.0.0",
108
104
  "eslint": "^9.9.0",
109
- "karma": "^6.2.0",
110
- "karma-chrome-launcher": "^3.0.0",
111
- "karma-coverage": "^2.0.0",
112
- "karma-env-preprocessor": "^0.1.1",
113
- "karma-firefox-launcher": "^1.1.0",
114
- "karma-junit-reporter": "^2.0.1",
115
- "karma-mocha": "^2.0.1",
116
- "karma-mocha-reporter": "^2.2.5",
117
- "karma-source-map-support": "~1.4.0",
118
- "karma-sourcemap-loader": "^0.3.8",
119
- "mocha": "^10.0.0",
120
- "nyc": "^17.0.0",
121
- "source-map-support": "^0.5.9",
122
- "ts-node": "^10.0.0",
123
- "typescript": "~5.6.2"
105
+ "playwright": "^1.50.1",
106
+ "typescript": "~5.7.2",
107
+ "vitest": "^3.0.5"
124
108
  },
125
- "browser": {
126
- "./dist-esm/test/public/utils/env.js": "./dist-esm/test/public/utils/env.browser.js"
127
- }
109
+ "browser": "./dist/browser/index.js",
110
+ "type": "module",
111
+ "tshy": {
112
+ "project": "./tsconfig.src.json",
113
+ "exports": {
114
+ "./package.json": "./package.json",
115
+ ".": "./src/index.ts"
116
+ },
117
+ "dialects": [
118
+ "esm",
119
+ "commonjs"
120
+ ],
121
+ "esmDialects": [
122
+ "browser",
123
+ "react-native"
124
+ ],
125
+ "selfLink": false
126
+ },
127
+ "exports": {
128
+ "./package.json": "./package.json",
129
+ ".": {
130
+ "browser": {
131
+ "types": "./dist/browser/index.d.ts",
132
+ "default": "./dist/browser/index.js"
133
+ },
134
+ "react-native": {
135
+ "types": "./dist/react-native/index.d.ts",
136
+ "default": "./dist/react-native/index.js"
137
+ },
138
+ "import": {
139
+ "types": "./dist/esm/index.d.ts",
140
+ "default": "./dist/esm/index.js"
141
+ },
142
+ "require": {
143
+ "types": "./dist/commonjs/index.d.ts",
144
+ "default": "./dist/commonjs/index.js"
145
+ }
146
+ }
147
+ },
148
+ "react-native": "./dist/react-native/index.js"
128
149
  }
package/dist/index.js DELETED
@@ -1,340 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var coreAuth = require('@azure/core-auth');
6
- var mapsCommon = require('@azure/maps-common');
7
- var tslib = require('tslib');
8
- var coreClient = require('@azure-rest/core-client');
9
- var logger$1 = require('@azure/logger');
10
- var coreRestPipeline = require('@azure/core-rest-pipeline');
11
- var coreLro = require('@azure/core-lro');
12
-
13
- // Copyright (c) Microsoft Corporation.
14
- // Licensed under the MIT License.
15
- const logger = logger$1.createClientLogger("maps-route");
16
-
17
- // Copyright (c) Microsoft Corporation.
18
- // Licensed under the MIT License.
19
- /**
20
- * Initialize a new instance of `MapsRouteClient`
21
- * @param credentials - uniquely identify client credential
22
- * @param options - the parameter for all optional parameters
23
- */
24
- function createClient(credentials, _a = {}) {
25
- var _b, _c, _d, _e, _f, _g;
26
- var { apiVersion = "1.0" } = _a, options = tslib.__rest(_a, ["apiVersion"]);
27
- const endpointUrl = (_c = (_b = options.endpoint) !== null && _b !== void 0 ? _b : options.baseUrl) !== null && _c !== void 0 ? _c : `https://atlas.microsoft.com`;
28
- const userAgentInfo = `azsdk-js-maps-route-rest/1.0.0-beta.4`;
29
- const userAgentPrefix = options.userAgentOptions && options.userAgentOptions.userAgentPrefix
30
- ? `${options.userAgentOptions.userAgentPrefix} ${userAgentInfo}`
31
- : `${userAgentInfo}`;
32
- options = Object.assign(Object.assign({}, options), { userAgentOptions: {
33
- userAgentPrefix,
34
- }, loggingOptions: {
35
- logger: (_e = (_d = options.loggingOptions) === null || _d === void 0 ? void 0 : _d.logger) !== null && _e !== void 0 ? _e : logger.info,
36
- }, credentials: {
37
- apiKeyHeaderName: (_g = (_f = options.credentials) === null || _f === void 0 ? void 0 : _f.apiKeyHeaderName) !== null && _g !== void 0 ? _g : "subscription-key",
38
- } });
39
- const client = coreClient.getClient(endpointUrl, credentials, options);
40
- client.pipeline.removePolicy({ name: "ApiVersionPolicy" });
41
- client.pipeline.addPolicy({
42
- name: "ClientApiVersionPolicy",
43
- sendRequest: (req, next) => {
44
- // Use the apiVersion defined in request url directly
45
- // Append one if there is no apiVersion and we have one at client options
46
- const url = new URL(req.url);
47
- if (!url.searchParams.get("api-version") && apiVersion) {
48
- req.url = `${req.url}${Array.from(url.searchParams.keys()).length > 0 ? "&" : "?"}api-version=${apiVersion}`;
49
- }
50
- return next(req);
51
- },
52
- });
53
- return client;
54
- }
55
-
56
- // Copyright (c) Microsoft Corporation.
57
- // Licensed under the MIT License.
58
- const responseMap = {
59
- "GET /route/matrix/{format}": ["200", "202"],
60
- "POST /route/matrix/{format}": ["200", "202"],
61
- "POST /route/matrix/sync/{format}": ["200"],
62
- "GET /route/directions/{format}": ["200"],
63
- "POST /route/directions/{format}": ["200"],
64
- "GET /route/range/{format}": ["200"],
65
- "GET /route/directions/batch/{format}": ["200", "202"],
66
- "POST /route/directions/batch/{format}": ["200", "202"],
67
- "POST /route/directions/batch/sync/{format}": ["200"],
68
- };
69
- function isUnexpected(response) {
70
- const lroOriginal = response.headers["x-ms-original-url"];
71
- const url = new URL(lroOriginal !== null && lroOriginal !== void 0 ? lroOriginal : response.request.url);
72
- const method = response.request.method;
73
- let pathDetails = responseMap[`${method} ${url.pathname}`];
74
- if (!pathDetails) {
75
- pathDetails = getParametrizedPathSuccess(method, url.pathname);
76
- }
77
- return !pathDetails.includes(response.status);
78
- }
79
- function getParametrizedPathSuccess(method, path) {
80
- var _a, _b, _c, _d;
81
- const pathParts = path.split("/");
82
- // Traverse list to match the longest candidate
83
- // matchedLen: the length of candidate path
84
- // matchedValue: the matched status code array
85
- let matchedLen = -1, matchedValue = [];
86
- // Iterate the responseMap to find a match
87
- for (const [key, value] of Object.entries(responseMap)) {
88
- // Extracting the path from the map key which is in format
89
- // GET /path/foo
90
- if (!key.startsWith(method)) {
91
- continue;
92
- }
93
- const candidatePath = getPathFromMapKey(key);
94
- // Get each part of the url path
95
- const candidateParts = candidatePath.split("/");
96
- // track if we have found a match to return the values found.
97
- let found = true;
98
- for (let i = candidateParts.length - 1, j = pathParts.length - 1; i >= 1 && j >= 1; i--, j--) {
99
- if (((_a = candidateParts[i]) === null || _a === void 0 ? void 0 : _a.startsWith("{")) &&
100
- ((_b = candidateParts[i]) === null || _b === void 0 ? void 0 : _b.indexOf("}")) !== -1) {
101
- const start = candidateParts[i].indexOf("}") + 1, end = (_c = candidateParts[i]) === null || _c === void 0 ? void 0 : _c.length;
102
- // If the current part of the candidate is a "template" part
103
- // Try to use the suffix of pattern to match the path
104
- // {guid} ==> $
105
- // {guid}:export ==> :export$
106
- const isMatched = new RegExp(`${(_d = candidateParts[i]) === null || _d === void 0 ? void 0 : _d.slice(start, end)}`).test(pathParts[j] || "");
107
- if (!isMatched) {
108
- found = false;
109
- break;
110
- }
111
- continue;
112
- }
113
- // If the candidate part is not a template and
114
- // the parts don't match mark the candidate as not found
115
- // to move on with the next candidate path.
116
- if (candidateParts[i] !== pathParts[j]) {
117
- found = false;
118
- break;
119
- }
120
- }
121
- // We finished evaluating the current candidate parts
122
- // Update the matched value if and only if we found the longer pattern
123
- if (found && candidatePath.length > matchedLen) {
124
- matchedLen = candidatePath.length;
125
- matchedValue = value;
126
- }
127
- }
128
- return matchedValue;
129
- }
130
- function getPathFromMapKey(mapKey) {
131
- const pathStart = mapKey.indexOf("/");
132
- return mapKey.slice(pathStart);
133
- }
134
-
135
- // Copyright (c) Microsoft Corporation.
136
- // Licensed under the MIT License.
137
- /**
138
- * Helper function that builds a Poller object to help polling a long running operation.
139
- * @param client - Client to use for sending the request to get additional pages.
140
- * @param initialResponse - The initial response.
141
- * @param options - Options to set a resume state or custom polling interval.
142
- * @returns - A poller object to poll for operation state updates and eventually get the final response.
143
- */
144
- async function getLongRunningPoller(client, initialResponse, options = {}) {
145
- var _a;
146
- const abortController = new AbortController();
147
- const poller = {
148
- sendInitialRequest: async () => {
149
- // In the case of Rest Clients we are building the LRO poller object from a response that's the reason
150
- // we are not triggering the initial request here, just extracting the information from the
151
- // response we were provided.
152
- return getLroResponse(initialResponse);
153
- },
154
- sendPollRequest: async (path, pollOptions) => {
155
- // This is the callback that is going to be called to poll the service
156
- // to get the latest status. We use the client provided and the polling path
157
- // which is an opaque URL provided by caller, the service sends this in one of the following headers: operation-location, azure-asyncoperation or location
158
- // depending on the lro pattern that the service implements. If non is provided we default to the initial path.
159
- function abortListener() {
160
- abortController.abort();
161
- }
162
- const inputAbortSignal = pollOptions === null || pollOptions === void 0 ? void 0 : pollOptions.abortSignal;
163
- const abortSignal = abortController.signal;
164
- if (inputAbortSignal === null || inputAbortSignal === void 0 ? void 0 : inputAbortSignal.aborted) {
165
- abortController.abort();
166
- }
167
- else if (!abortSignal.aborted) {
168
- inputAbortSignal === null || inputAbortSignal === void 0 ? void 0 : inputAbortSignal.addEventListener("abort", abortListener, {
169
- once: true,
170
- });
171
- }
172
- let response;
173
- try {
174
- response = await client
175
- .pathUnchecked(path !== null && path !== void 0 ? path : initialResponse.request.url)
176
- .get({ abortSignal });
177
- }
178
- finally {
179
- inputAbortSignal === null || inputAbortSignal === void 0 ? void 0 : inputAbortSignal.removeEventListener("abort", abortListener);
180
- }
181
- const lroResponse = getLroResponse(response);
182
- lroResponse.rawResponse.headers["x-ms-original-url"] =
183
- initialResponse.request.url;
184
- return lroResponse;
185
- },
186
- };
187
- options.resolveOnUnsuccessful = (_a = options.resolveOnUnsuccessful) !== null && _a !== void 0 ? _a : true;
188
- const httpPoller = coreLro.createHttpPoller(poller, options);
189
- const simplePoller = {
190
- isDone() {
191
- return httpPoller.isDone;
192
- },
193
- isStopped() {
194
- return abortController.signal.aborted;
195
- },
196
- getOperationState() {
197
- if (!httpPoller.operationState) {
198
- throw new Error("Operation state is not available. The poller may not have been started and you could await submitted() before calling getOperationState().");
199
- }
200
- return httpPoller.operationState;
201
- },
202
- getResult() {
203
- return httpPoller.result;
204
- },
205
- toString() {
206
- if (!httpPoller.operationState) {
207
- throw new Error("Operation state is not available. The poller may not have been started and you could await submitted() before calling getOperationState().");
208
- }
209
- return JSON.stringify({
210
- state: httpPoller.operationState,
211
- });
212
- },
213
- stopPolling() {
214
- abortController.abort();
215
- },
216
- onProgress: httpPoller.onProgress,
217
- poll: httpPoller.poll,
218
- pollUntilDone: httpPoller.pollUntilDone,
219
- serialize: httpPoller.serialize,
220
- submitted: httpPoller.submitted,
221
- };
222
- return simplePoller;
223
- }
224
- /**
225
- * Converts a Rest Client response to a response that the LRO implementation understands
226
- * @param response - a rest client http response
227
- * @returns - An LRO response that the LRO implementation understands
228
- */
229
- function getLroResponse(response) {
230
- if (Number.isNaN(response.status)) {
231
- throw new TypeError(`Status code of the response is not a number. Value: ${response.status}`);
232
- }
233
- return {
234
- flatResponse: response,
235
- rawResponse: Object.assign(Object.assign({}, response), { statusCode: Number.parseInt(response.status), body: response.body }),
236
- };
237
- }
238
-
239
- // Copyright (c) Microsoft Corporation.
240
- // Licensed under the MIT License.
241
- function buildMultiCollection(items, parameterName) {
242
- return items
243
- .map((item, index) => {
244
- if (index === 0) {
245
- return item;
246
- }
247
- return `${parameterName}=${item}`;
248
- })
249
- .join("&");
250
- }
251
-
252
- // Copyright (c) Microsoft Corporation.
253
- // Licensed under the MIT License.
254
- function MapsRoute(credential, clientIdOrOptions = {}, maybeOptions = {}) {
255
- const options = typeof clientIdOrOptions === "string" ? maybeOptions : clientIdOrOptions;
256
- /**
257
- * maps service requires a header "ms-x-client-id", which is different from the standard Microsoft Entra ID.
258
- * So we need to do our own implementation.
259
- * This customized authentication is following by this guide: https://github.com/Azure/azure-sdk-for-js/blob/main/documentation/RLC-customization.md#custom-authentication
260
- */
261
- if (coreAuth.isTokenCredential(credential)) {
262
- const clientId = typeof clientIdOrOptions === "string" ? clientIdOrOptions : "";
263
- if (!clientId) {
264
- throw Error("Client id is needed for TokenCredential");
265
- }
266
- const client = createClient(undefined, options);
267
- client.pipeline.addPolicy(coreRestPipeline.bearerTokenAuthenticationPolicy({
268
- credential,
269
- scopes: "https://atlas.microsoft.com/.default",
270
- }));
271
- client.pipeline.addPolicy(mapsCommon.createMapsClientIdPolicy(clientId));
272
- return client;
273
- }
274
- if (coreAuth.isSASCredential(credential)) {
275
- const client = createClient(undefined, options);
276
- client.pipeline.addPolicy({
277
- name: "mapsSASCredentialPolicy",
278
- async sendRequest(request, next) {
279
- request.headers.set("Authorization", `jwt-sas ${credential.signature}`);
280
- return next(request);
281
- },
282
- });
283
- return client;
284
- }
285
- return createClient(credential, options);
286
- }
287
-
288
- // Copyright (c) Microsoft Corporation.
289
- // Licensed under the MIT License.
290
- function toLatLonString(coordinates) {
291
- return `${coordinates[0]},${coordinates[1]}`;
292
- }
293
- /**
294
- * Transform an array of [Latitude, Longtitute] to a string in the following format:
295
- * "Latitude_1,Longtitute_1:Latitude_2,Longtitute_2:..."
296
- *
297
- * @param coordinates - An array of Latitude/Longtitute pair to transform.
298
- * @returns The transformed string.
299
- */
300
- function toColonDelimitedLatLonString(coordinates) {
301
- return coordinates.map((c) => toLatLonString(c)).join(":");
302
- }
303
- /**
304
- * Create a batch request body of a bunch of route direction requests.
305
- *
306
- * @param queryParamProperties - An object of the query parameters for a route direction request
307
- * @returns The composed batch request.
308
- */
309
- function createRouteDirectionsBatchRequest(queryParamProperties) {
310
- return {
311
- batchItems: queryParamProperties.map((queryParam) => ({
312
- query: "?" +
313
- Object.entries(queryParam)
314
- .map(([k, v]) => {
315
- // Skip if no value
316
- if (typeof v === "undefined" || v === null) {
317
- return "";
318
- }
319
- // Check name mappings: Array values
320
- if ((k === "departAt" || k === "arriveAt") && v instanceof Date) {
321
- return `${k}=${v.toISOString()}`;
322
- }
323
- return `${k}=${v}`;
324
- })
325
- .filter((s) => s !== "")
326
- .join("&"),
327
- })),
328
- };
329
- }
330
-
331
- // Copyright (c) Microsoft Corporation.
332
- // Licensed under the MIT License.
333
-
334
- exports.buildMultiCollection = buildMultiCollection;
335
- exports.createRouteDirectionsBatchRequest = createRouteDirectionsBatchRequest;
336
- exports.default = MapsRoute;
337
- exports.getLongRunningPoller = getLongRunningPoller;
338
- exports.isUnexpected = isUnexpected;
339
- exports.toColonDelimitedLatLonString = toColonDelimitedLatLonString;
340
- //# sourceMappingURL=index.js.map
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":["../generated/logger.ts","../generated/mapsRouteClient.ts","../generated/isUnexpected.ts","../generated/pollingHelper.ts","../generated/serializeHelper.ts","../src/mapsRoute.ts","../src/helpers.ts","../src/index.ts"],"sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { createClientLogger } from \"@azure/logger\";\nexport const logger = createClientLogger(\"maps-route\");\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { getClient, ClientOptions } from \"@azure-rest/core-client\";\nimport { logger } from \"./logger\";\nimport { KeyCredential } from \"@azure/core-auth\";\nimport { MapsRouteClient } from \"./clientDefinitions\";\n\n/** The optional parameters for the client */\nexport interface MapsRouteClientOptions extends ClientOptions {\n /** The api version option of the client */\n apiVersion?: string;\n}\n\n/**\n * Initialize a new instance of `MapsRouteClient`\n * @param credentials - uniquely identify client credential\n * @param options - the parameter for all optional parameters\n */\nexport default function createClient(\n credentials: KeyCredential,\n { apiVersion = \"1.0\", ...options }: MapsRouteClientOptions = {},\n): MapsRouteClient {\n const endpointUrl =\n options.endpoint ?? options.baseUrl ?? `https://atlas.microsoft.com`;\n const userAgentInfo = `azsdk-js-maps-route-rest/1.0.0-beta.4`;\n const userAgentPrefix =\n options.userAgentOptions && options.userAgentOptions.userAgentPrefix\n ? `${options.userAgentOptions.userAgentPrefix} ${userAgentInfo}`\n : `${userAgentInfo}`;\n options = {\n ...options,\n userAgentOptions: {\n userAgentPrefix,\n },\n loggingOptions: {\n logger: options.loggingOptions?.logger ?? logger.info,\n },\n credentials: {\n apiKeyHeaderName:\n options.credentials?.apiKeyHeaderName ?? \"subscription-key\",\n },\n };\n const client = getClient(\n endpointUrl,\n credentials,\n options,\n ) as MapsRouteClient;\n\n client.pipeline.removePolicy({ name: \"ApiVersionPolicy\" });\n client.pipeline.addPolicy({\n name: \"ClientApiVersionPolicy\",\n sendRequest: (req, next) => {\n // Use the apiVersion defined in request url directly\n // Append one if there is no apiVersion and we have one at client options\n const url = new URL(req.url);\n if (!url.searchParams.get(\"api-version\") && apiVersion) {\n req.url = `${req.url}${\n Array.from(url.searchParams.keys()).length > 0 ? \"&\" : \"?\"\n }api-version=${apiVersion}`;\n }\n\n return next(req);\n },\n });\n\n return client;\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport {\n RouteRequestRouteMatrixSync200Response,\n RouteRequestRouteMatrixSync408Response,\n RouteRequestRouteMatrixSyncDefaultResponse,\n RouteGetRouteDirections200Response,\n RouteGetRouteDirectionsDefaultResponse,\n RouteGetRouteDirectionsWithAdditionalParameters200Response,\n RouteGetRouteDirectionsWithAdditionalParametersDefaultResponse,\n RouteGetRouteRange200Response,\n RouteGetRouteRangeDefaultResponse,\n RouteRequestRouteDirectionsBatchSync200Response,\n RouteRequestRouteDirectionsBatchSync408Response,\n RouteRequestRouteDirectionsBatchSyncDefaultResponse,\n} from \"./responses\";\n\nconst responseMap: Record<string, string[]> = {\n \"GET /route/matrix/{format}\": [\"200\", \"202\"],\n \"POST /route/matrix/{format}\": [\"200\", \"202\"],\n \"POST /route/matrix/sync/{format}\": [\"200\"],\n \"GET /route/directions/{format}\": [\"200\"],\n \"POST /route/directions/{format}\": [\"200\"],\n \"GET /route/range/{format}\": [\"200\"],\n \"GET /route/directions/batch/{format}\": [\"200\", \"202\"],\n \"POST /route/directions/batch/{format}\": [\"200\", \"202\"],\n \"POST /route/directions/batch/sync/{format}\": [\"200\"],\n};\n\nexport function isUnexpected(\n response:\n | RouteRequestRouteMatrixSync200Response\n | RouteRequestRouteMatrixSync408Response\n | RouteRequestRouteMatrixSyncDefaultResponse,\n): response is RouteRequestRouteMatrixSync408Response;\nexport function isUnexpected(\n response:\n | RouteGetRouteDirections200Response\n | RouteGetRouteDirectionsDefaultResponse,\n): response is RouteGetRouteDirectionsDefaultResponse;\nexport function isUnexpected(\n response:\n | RouteGetRouteDirectionsWithAdditionalParameters200Response\n | RouteGetRouteDirectionsWithAdditionalParametersDefaultResponse,\n): response is RouteGetRouteDirectionsWithAdditionalParametersDefaultResponse;\nexport function isUnexpected(\n response: RouteGetRouteRange200Response | RouteGetRouteRangeDefaultResponse,\n): response is RouteGetRouteRangeDefaultResponse;\nexport function isUnexpected(\n response:\n | RouteRequestRouteDirectionsBatchSync200Response\n | RouteRequestRouteDirectionsBatchSync408Response\n | RouteRequestRouteDirectionsBatchSyncDefaultResponse,\n): response is RouteRequestRouteDirectionsBatchSync408Response;\nexport function isUnexpected(\n response:\n | RouteRequestRouteMatrixSync200Response\n | RouteRequestRouteMatrixSync408Response\n | RouteRequestRouteMatrixSyncDefaultResponse\n | RouteGetRouteDirections200Response\n | RouteGetRouteDirectionsDefaultResponse\n | RouteGetRouteDirectionsWithAdditionalParameters200Response\n | RouteGetRouteDirectionsWithAdditionalParametersDefaultResponse\n | RouteGetRouteRange200Response\n | RouteGetRouteRangeDefaultResponse\n | RouteRequestRouteDirectionsBatchSync200Response\n | RouteRequestRouteDirectionsBatchSync408Response\n | RouteRequestRouteDirectionsBatchSyncDefaultResponse,\n): response is\n | RouteRequestRouteMatrixSync408Response\n | RouteRequestRouteMatrixSyncDefaultResponse\n | RouteGetRouteDirectionsDefaultResponse\n | RouteGetRouteDirectionsWithAdditionalParametersDefaultResponse\n | RouteGetRouteRangeDefaultResponse\n | RouteRequestRouteDirectionsBatchSync408Response\n | RouteRequestRouteDirectionsBatchSyncDefaultResponse {\n const lroOriginal = response.headers[\"x-ms-original-url\"];\n const url = new URL(lroOriginal ?? response.request.url);\n const method = response.request.method;\n let pathDetails = responseMap[`${method} ${url.pathname}`];\n if (!pathDetails) {\n pathDetails = getParametrizedPathSuccess(method, url.pathname);\n }\n return !pathDetails.includes(response.status);\n}\n\nfunction getParametrizedPathSuccess(method: string, path: string): string[] {\n const pathParts = path.split(\"/\");\n\n // Traverse list to match the longest candidate\n // matchedLen: the length of candidate path\n // matchedValue: the matched status code array\n let matchedLen = -1,\n matchedValue: string[] = [];\n\n // Iterate the responseMap to find a match\n for (const [key, value] of Object.entries(responseMap)) {\n // Extracting the path from the map key which is in format\n // GET /path/foo\n if (!key.startsWith(method)) {\n continue;\n }\n const candidatePath = getPathFromMapKey(key);\n // Get each part of the url path\n const candidateParts = candidatePath.split(\"/\");\n\n // track if we have found a match to return the values found.\n let found = true;\n for (\n let i = candidateParts.length - 1, j = pathParts.length - 1;\n i >= 1 && j >= 1;\n i--, j--\n ) {\n if (\n candidateParts[i]?.startsWith(\"{\") &&\n candidateParts[i]?.indexOf(\"}\") !== -1\n ) {\n const start = candidateParts[i]!.indexOf(\"}\") + 1,\n end = candidateParts[i]?.length;\n // If the current part of the candidate is a \"template\" part\n // Try to use the suffix of pattern to match the path\n // {guid} ==> $\n // {guid}:export ==> :export$\n const isMatched = new RegExp(\n `${candidateParts[i]?.slice(start, end)}`,\n ).test(pathParts[j] || \"\");\n\n if (!isMatched) {\n found = false;\n break;\n }\n continue;\n }\n\n // If the candidate part is not a template and\n // the parts don't match mark the candidate as not found\n // to move on with the next candidate path.\n if (candidateParts[i] !== pathParts[j]) {\n found = false;\n break;\n }\n }\n\n // We finished evaluating the current candidate parts\n // Update the matched value if and only if we found the longer pattern\n if (found && candidatePath.length > matchedLen) {\n matchedLen = candidatePath.length;\n matchedValue = value;\n }\n }\n\n return matchedValue;\n}\n\nfunction getPathFromMapKey(mapKey: string): string {\n const pathStart = mapKey.indexOf(\"/\");\n return mapKey.slice(pathStart);\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { Client, HttpResponse } from \"@azure-rest/core-client\";\nimport { AbortSignalLike } from \"@azure/abort-controller\";\nimport {\n CancelOnProgress,\n CreateHttpPollerOptions,\n RunningOperation,\n OperationResponse,\n OperationState,\n createHttpPoller,\n} from \"@azure/core-lro\";\n\n/**\n * A simple poller that can be used to poll a long running operation.\n */\nexport interface SimplePollerLike<\n TState extends OperationState<TResult>,\n TResult,\n> {\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?: {\n abortSignal?: AbortSignalLike;\n }): 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 * Helper function that builds a Poller object to help polling a long running operation.\n * @param client - Client to use for sending the request to get additional pages.\n * @param initialResponse - The initial response.\n * @param options - Options to set a resume state or custom polling interval.\n * @returns - A poller object to poll for operation state updates and eventually get the final response.\n */\nexport async function getLongRunningPoller<TResult extends HttpResponse>(\n client: Client,\n initialResponse: TResult,\n options: CreateHttpPollerOptions<TResult, OperationState<TResult>> = {},\n): Promise<SimplePollerLike<OperationState<TResult>, TResult>> {\n const abortController = new AbortController();\n const poller: RunningOperation<TResult> = {\n sendInitialRequest: async () => {\n // In the case of Rest Clients we are building the LRO poller object from a response that's the reason\n // we are not triggering the initial request here, just extracting the information from the\n // response we were provided.\n return getLroResponse(initialResponse);\n },\n sendPollRequest: async (\n path: string,\n pollOptions?: { abortSignal?: AbortSignalLike },\n ) => {\n // This is the callback that is going to be called to poll the service\n // to get the latest status. We use the client provided and the polling path\n // which is an opaque URL provided by caller, the service sends this in one of the following headers: operation-location, azure-asyncoperation or location\n // depending on the lro pattern that the service implements. If non is provided we default to the initial path.\n function abortListener(): void {\n abortController.abort();\n }\n const inputAbortSignal = pollOptions?.abortSignal;\n const abortSignal = abortController.signal;\n if (inputAbortSignal?.aborted) {\n abortController.abort();\n } else if (!abortSignal.aborted) {\n inputAbortSignal?.addEventListener(\"abort\", abortListener, {\n once: true,\n });\n }\n let response;\n try {\n response = await client\n .pathUnchecked(path ?? initialResponse.request.url)\n .get({ abortSignal });\n } finally {\n inputAbortSignal?.removeEventListener(\"abort\", abortListener);\n }\n const lroResponse = getLroResponse(response as TResult);\n lroResponse.rawResponse.headers[\"x-ms-original-url\"] =\n initialResponse.request.url;\n return lroResponse;\n },\n };\n\n options.resolveOnUnsuccessful = options.resolveOnUnsuccessful ?? true;\n const httpPoller = createHttpPoller(poller, options);\n const simplePoller: SimplePollerLike<OperationState<TResult>, TResult> = {\n isDone() {\n return httpPoller.isDone;\n },\n isStopped() {\n return abortController.signal.aborted;\n },\n getOperationState() {\n if (!httpPoller.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 httpPoller.operationState;\n },\n getResult() {\n return httpPoller.result;\n },\n toString() {\n if (!httpPoller.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: httpPoller.operationState,\n });\n },\n stopPolling() {\n abortController.abort();\n },\n onProgress: httpPoller.onProgress,\n poll: httpPoller.poll,\n pollUntilDone: httpPoller.pollUntilDone,\n serialize: httpPoller.serialize,\n submitted: httpPoller.submitted,\n };\n return simplePoller;\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 * @returns - An LRO response that the LRO implementation understands\n */\nfunction getLroResponse<TResult extends HttpResponse>(\n response: TResult,\n): OperationResponse<TResult> {\n if (Number.isNaN(response.status)) {\n throw new TypeError(\n `Status code of the response is not a number. Value: ${response.status}`,\n );\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","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport function buildMultiCollection(\n items: string[],\n parameterName: string,\n): string {\n return items\n .map((item, index) => {\n if (index === 0) {\n return item;\n }\n return `${parameterName}=${item}`;\n })\n .join(\"&\");\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { ClientOptions } from \"@azure-rest/core-client\";\nimport type { AzureKeyCredential, AzureSASCredential, TokenCredential } from \"@azure/core-auth\";\nimport { isSASCredential, isTokenCredential } from \"@azure/core-auth\";\nimport { createMapsClientIdPolicy } from \"@azure/maps-common\";\nimport type { MapsRouteClient } from \"../generated\";\nimport createClient from \"../generated\";\nimport { bearerTokenAuthenticationPolicy } from \"@azure/core-rest-pipeline\";\n\n/**\n * Creates an instance of MapsRouteClient from a subscription key.\n *\n * @example\n * ```ts\n * import MapsRoute from \"@azure-rest/maps-route\";\n * import { AzureKeyCredential } from \"@azure/core-auth\";\n *\n * const credential = new AzureKeyCredential(\"<subscription-key>\");\n * const client = MapsRoute(credential);\n *```\n *\n * @param credential - An AzureKeyCredential instance used to authenticate requests to the service\n * @param options - Options used to configure the Route Client\n */\nexport default function MapsRoute(\n credential: AzureKeyCredential,\n options?: ClientOptions,\n): MapsRouteClient;\n/**\n * Creates an instance of MapsRoute from an Azure Identity `TokenCredential`.\n *\n * @example\n * ```ts\n * import MapsRoute from \"@azure-rest/maps-route\";\n * import { DefaultAzureCredential } from \"@azure/identity\";\n *\n * const credential = new DefaultAzureCredential();\n * const client = MapsRoute(credential, \"<maps-account-client-id>\");\n *```\n *\n * @param credential - An TokenCredential instance used to authenticate requests to the service\n * @param mapsAccountClientId - The Azure Maps client id of a specific map resource\n * @param options - Options used to configure the Route Client\n */\nexport default function MapsRoute(\n credential: TokenCredential,\n mapsAccountClientId: string,\n options?: ClientOptions,\n): MapsRouteClient;\n/**\n * Creates an instance of MapsRoute from an Azure Identity `AzureSASCredential`.\n *\n * @example\n * ```ts\n * import MapsRoute from \"@azure-rest/maps-route\";\n * import { AzureSASCredential } from \"@azure/core-auth\";\n *\n * const credential = new AzureSASCredential(\"<SAS Token>\");\n * const client = MapsRoute(credential);\n * ```\n *\n * @param credential - An AzureSASCredential instance used to authenticate requests to the service\n * @param options - Options used to configure the Route Client\n */\nexport default function MapsRoute(\n credential: AzureSASCredential,\n options?: ClientOptions,\n): MapsRouteClient;\nexport default function MapsRoute(\n credential: TokenCredential | AzureKeyCredential | AzureSASCredential,\n clientIdOrOptions: string | ClientOptions = {},\n maybeOptions: ClientOptions = {},\n): MapsRouteClient {\n const options = typeof clientIdOrOptions === \"string\" ? maybeOptions : clientIdOrOptions;\n\n /**\n * maps service requires a header \"ms-x-client-id\", which is different from the standard Microsoft Entra ID.\n * So we need to do our own implementation.\n * This customized authentication is following by this guide: https://github.com/Azure/azure-sdk-for-js/blob/main/documentation/RLC-customization.md#custom-authentication\n */\n if (isTokenCredential(credential)) {\n const clientId = typeof clientIdOrOptions === \"string\" ? clientIdOrOptions : \"\";\n if (!clientId) {\n throw Error(\"Client id is needed for TokenCredential\");\n }\n const client = createClient(undefined as any, options);\n client.pipeline.addPolicy(\n bearerTokenAuthenticationPolicy({\n credential,\n scopes: \"https://atlas.microsoft.com/.default\",\n }),\n );\n client.pipeline.addPolicy(createMapsClientIdPolicy(clientId));\n return client;\n }\n\n if (isSASCredential(credential)) {\n const client = createClient(undefined as any, options);\n client.pipeline.addPolicy({\n name: \"mapsSASCredentialPolicy\",\n async sendRequest(request, next) {\n request.headers.set(\"Authorization\", `jwt-sas ${credential.signature}`);\n return next(request);\n },\n });\n return client;\n }\n\n return createClient(credential, options);\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { LatLon } from \"@azure/maps-common\";\nimport type { BatchRequest, RouteGetRouteDirectionsQueryParamProperties } from \"../generated\";\n\nfunction toLatLonString(coordinates: LatLon): string {\n return `${coordinates[0]},${coordinates[1]}`;\n}\n\n/**\n * Transform an array of [Latitude, Longtitute] to a string in the following format:\n * \"Latitude_1,Longtitute_1:Latitude_2,Longtitute_2:...\"\n *\n * @param coordinates - An array of Latitude/Longtitute pair to transform.\n * @returns The transformed string.\n */\nexport function toColonDelimitedLatLonString(coordinates: LatLon[]): string {\n return coordinates.map((c) => toLatLonString(c)).join(\":\");\n}\n\n/**\n * Create a batch request body of a bunch of route direction requests.\n *\n * @param queryParamProperties - An object of the query parameters for a route direction request\n * @returns The composed batch request.\n */\nexport function createRouteDirectionsBatchRequest(\n queryParamProperties: RouteGetRouteDirectionsQueryParamProperties[],\n): BatchRequest {\n return {\n batchItems: queryParamProperties.map((queryParam) => ({\n query:\n \"?\" +\n Object.entries(queryParam)\n .map(([k, v]) => {\n // Skip if no value\n if (typeof v === \"undefined\" || v === null) {\n return \"\";\n }\n // Check name mappings: Array values\n if ((k === \"departAt\" || k === \"arriveAt\") && v instanceof Date) {\n return `${k}=${v.toISOString()}`;\n }\n return `${k}=${v}`;\n })\n .filter((s) => s !== \"\")\n .join(\"&\"),\n })),\n };\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport MapsRoute from \"./mapsRoute\";\n\nexport * from \"../generated\";\nexport * from \"./helpers\";\n\nexport default MapsRoute;\n"],"names":["createClientLogger","__rest","getClient","createHttpPoller","isTokenCredential","bearerTokenAuthenticationPolicy","createMapsClientIdPolicy","isSASCredential"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/helpers.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAKlC,SAAS,cAAc,CAAC,WAAmB;IACzC,OAAO,GAAG,WAAW,CAAC,CAAC,CAAC,IAAI,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;AAC/C,CAAC;AAED;;;;;;GAMG;AACH,MAAM,UAAU,4BAA4B,CAAC,WAAqB;IAChE,OAAO,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC7D,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,iCAAiC,CAC/C,oBAAmE;IAEnE,OAAO;QACL,UAAU,EAAE,oBAAoB,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YACpD,KAAK,EACH,GAAG;gBACH,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC;qBACvB,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE;oBACd,mBAAmB;oBACnB,IAAI,OAAO,CAAC,KAAK,WAAW,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC;wBAC3C,OAAO,EAAE,CAAC;oBACZ,CAAC;oBACD,oCAAoC;oBACpC,IAAI,CAAC,CAAC,KAAK,UAAU,IAAI,CAAC,KAAK,UAAU,CAAC,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC;wBAChE,OAAO,GAAG,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;oBACnC,CAAC;oBACD,OAAO,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBACrB,CAAC,CAAC;qBACD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;qBACvB,IAAI,CAAC,GAAG,CAAC;SACf,CAAC,CAAC;KACJ,CAAC;AACJ,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { LatLon } from \"@azure/maps-common\";\nimport type { BatchRequest, RouteGetRouteDirectionsQueryParamProperties } from \"../generated\";\n\nfunction toLatLonString(coordinates: LatLon): string {\n return `${coordinates[0]},${coordinates[1]}`;\n}\n\n/**\n * Transform an array of [Latitude, Longtitute] to a string in the following format:\n * \"Latitude_1,Longtitute_1:Latitude_2,Longtitute_2:...\"\n *\n * @param coordinates - An array of Latitude/Longtitute pair to transform.\n * @returns The transformed string.\n */\nexport function toColonDelimitedLatLonString(coordinates: LatLon[]): string {\n return coordinates.map((c) => toLatLonString(c)).join(\":\");\n}\n\n/**\n * Create a batch request body of a bunch of route direction requests.\n *\n * @param queryParamProperties - An object of the query parameters for a route direction request\n * @returns The composed batch request.\n */\nexport function createRouteDirectionsBatchRequest(\n queryParamProperties: RouteGetRouteDirectionsQueryParamProperties[],\n): BatchRequest {\n return {\n batchItems: queryParamProperties.map((queryParam) => ({\n query:\n \"?\" +\n Object.entries(queryParam)\n .map(([k, v]) => {\n // Skip if no value\n if (typeof v === \"undefined\" || v === null) {\n return \"\";\n }\n // Check name mappings: Array values\n if ((k === \"departAt\" || k === \"arriveAt\") && v instanceof Date) {\n return `${k}=${v.toISOString()}`;\n }\n return `${k}=${v}`;\n })\n .filter((s) => s !== \"\")\n .join(\"&\"),\n })),\n };\n}\n"]}
@@ -1,7 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import MapsRoute from "./mapsRoute";
4
- export * from "../generated";
5
- export * from "./helpers";
6
- export default MapsRoute;
7
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,SAAS,MAAM,aAAa,CAAC;AAEpC,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAE1B,eAAe,SAAS,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport MapsRoute from \"./mapsRoute\";\n\nexport * from \"../generated\";\nexport * from \"./helpers\";\n\nexport default MapsRoute;\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"mapsRoute.js","sourceRoot":"","sources":["../../src/mapsRoute.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAIlC,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,OAAO,YAAY,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,+BAA+B,EAAE,MAAM,2BAA2B,CAAC;AA6D5E,MAAM,CAAC,OAAO,UAAU,SAAS,CAC/B,UAAqE,EACrE,oBAA4C,EAAE,EAC9C,eAA8B,EAAE;IAEhC,MAAM,OAAO,GAAG,OAAO,iBAAiB,KAAK,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,iBAAiB,CAAC;IAEzF;;;;OAIG;IACH,IAAI,iBAAiB,CAAC,UAAU,CAAC,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,OAAO,iBAAiB,KAAK,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC;QAChF,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,KAAK,CAAC,yCAAyC,CAAC,CAAC;QACzD,CAAC;QACD,MAAM,MAAM,GAAG,YAAY,CAAC,SAAgB,EAAE,OAAO,CAAC,CAAC;QACvD,MAAM,CAAC,QAAQ,CAAC,SAAS,CACvB,+BAA+B,CAAC;YAC9B,UAAU;YACV,MAAM,EAAE,sCAAsC;SAC/C,CAAC,CACH,CAAC;QACF,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC9D,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,IAAI,eAAe,CAAC,UAAU,CAAC,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,YAAY,CAAC,SAAgB,EAAE,OAAO,CAAC,CAAC;QACvD,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC;YACxB,IAAI,EAAE,yBAAyB;YAC/B,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI;gBAC7B,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,WAAW,UAAU,CAAC,SAAS,EAAE,CAAC,CAAC;gBACxE,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC;YACvB,CAAC;SACF,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,OAAO,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;AAC3C,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { ClientOptions } from \"@azure-rest/core-client\";\nimport type { AzureKeyCredential, AzureSASCredential, TokenCredential } from \"@azure/core-auth\";\nimport { isSASCredential, isTokenCredential } from \"@azure/core-auth\";\nimport { createMapsClientIdPolicy } from \"@azure/maps-common\";\nimport type { MapsRouteClient } from \"../generated\";\nimport createClient from \"../generated\";\nimport { bearerTokenAuthenticationPolicy } from \"@azure/core-rest-pipeline\";\n\n/**\n * Creates an instance of MapsRouteClient from a subscription key.\n *\n * @example\n * ```ts\n * import MapsRoute from \"@azure-rest/maps-route\";\n * import { AzureKeyCredential } from \"@azure/core-auth\";\n *\n * const credential = new AzureKeyCredential(\"<subscription-key>\");\n * const client = MapsRoute(credential);\n *```\n *\n * @param credential - An AzureKeyCredential instance used to authenticate requests to the service\n * @param options - Options used to configure the Route Client\n */\nexport default function MapsRoute(\n credential: AzureKeyCredential,\n options?: ClientOptions,\n): MapsRouteClient;\n/**\n * Creates an instance of MapsRoute from an Azure Identity `TokenCredential`.\n *\n * @example\n * ```ts\n * import MapsRoute from \"@azure-rest/maps-route\";\n * import { DefaultAzureCredential } from \"@azure/identity\";\n *\n * const credential = new DefaultAzureCredential();\n * const client = MapsRoute(credential, \"<maps-account-client-id>\");\n *```\n *\n * @param credential - An TokenCredential instance used to authenticate requests to the service\n * @param mapsAccountClientId - The Azure Maps client id of a specific map resource\n * @param options - Options used to configure the Route Client\n */\nexport default function MapsRoute(\n credential: TokenCredential,\n mapsAccountClientId: string,\n options?: ClientOptions,\n): MapsRouteClient;\n/**\n * Creates an instance of MapsRoute from an Azure Identity `AzureSASCredential`.\n *\n * @example\n * ```ts\n * import MapsRoute from \"@azure-rest/maps-route\";\n * import { AzureSASCredential } from \"@azure/core-auth\";\n *\n * const credential = new AzureSASCredential(\"<SAS Token>\");\n * const client = MapsRoute(credential);\n * ```\n *\n * @param credential - An AzureSASCredential instance used to authenticate requests to the service\n * @param options - Options used to configure the Route Client\n */\nexport default function MapsRoute(\n credential: AzureSASCredential,\n options?: ClientOptions,\n): MapsRouteClient;\nexport default function MapsRoute(\n credential: TokenCredential | AzureKeyCredential | AzureSASCredential,\n clientIdOrOptions: string | ClientOptions = {},\n maybeOptions: ClientOptions = {},\n): MapsRouteClient {\n const options = typeof clientIdOrOptions === \"string\" ? maybeOptions : clientIdOrOptions;\n\n /**\n * maps service requires a header \"ms-x-client-id\", which is different from the standard Microsoft Entra ID.\n * So we need to do our own implementation.\n * This customized authentication is following by this guide: https://github.com/Azure/azure-sdk-for-js/blob/main/documentation/RLC-customization.md#custom-authentication\n */\n if (isTokenCredential(credential)) {\n const clientId = typeof clientIdOrOptions === \"string\" ? clientIdOrOptions : \"\";\n if (!clientId) {\n throw Error(\"Client id is needed for TokenCredential\");\n }\n const client = createClient(undefined as any, options);\n client.pipeline.addPolicy(\n bearerTokenAuthenticationPolicy({\n credential,\n scopes: \"https://atlas.microsoft.com/.default\",\n }),\n );\n client.pipeline.addPolicy(createMapsClientIdPolicy(clientId));\n return client;\n }\n\n if (isSASCredential(credential)) {\n const client = createClient(undefined as any, options);\n client.pipeline.addPolicy({\n name: \"mapsSASCredentialPolicy\",\n async sendRequest(request, next) {\n request.headers.set(\"Authorization\", `jwt-sas ${credential.signature}`);\n return next(request);\n },\n });\n return client;\n }\n\n return createClient(credential, options);\n}\n"]}