@azure/identity 4.6.0 → 4.6.1-alpha.20250116.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1115) hide show
  1. package/README.md +5 -1
  2. package/dist/browser/client/identityClient.d.ts +65 -0
  3. package/dist/browser/client/identityClient.d.ts.map +1 -0
  4. package/dist/browser/client/identityClient.js +248 -0
  5. package/dist/browser/client/identityClient.js.map +1 -0
  6. package/dist/browser/constants.d.ts +69 -0
  7. package/dist/browser/constants.d.ts.map +1 -0
  8. package/dist/browser/constants.js +75 -0
  9. package/dist/browser/constants.js.map +1 -0
  10. package/dist/browser/credentials/authorityValidationOptions.d.ts +16 -0
  11. package/dist/browser/credentials/authorityValidationOptions.d.ts.map +1 -0
  12. package/dist/browser/credentials/authorizationCodeCredential-browser.d.mts.map +1 -0
  13. package/dist/browser/credentials/authorizationCodeCredential-browser.mjs.map +1 -0
  14. package/dist/browser/credentials/authorizationCodeCredential.d.ts +11 -0
  15. package/dist/browser/credentials/authorizationCodeCredential.js +16 -0
  16. package/dist/browser/credentials/authorizationCodeCredentialOptions.d.ts +8 -0
  17. package/dist/browser/credentials/authorizationCodeCredentialOptions.d.ts.map +1 -0
  18. package/dist/browser/credentials/authorizationCodeCredentialOptions.js.map +1 -0
  19. package/dist/browser/credentials/azureApplicationCredential-browser.d.mts.map +1 -0
  20. package/dist/browser/credentials/azureApplicationCredential-browser.mjs.map +1 -0
  21. package/dist/browser/credentials/azureApplicationCredential.d.ts +24 -0
  22. package/dist/browser/credentials/azureApplicationCredential.js +34 -0
  23. package/dist/browser/credentials/azureApplicationCredentialOptions.d.ts +13 -0
  24. package/dist/browser/credentials/azureApplicationCredentialOptions.d.ts.map +1 -0
  25. package/dist/browser/credentials/azureApplicationCredentialOptions.js.map +1 -0
  26. package/dist/browser/credentials/azureCliCredential-browser.d.mts.map +1 -0
  27. package/dist/browser/credentials/azureCliCredential-browser.mjs.map +1 -0
  28. package/dist/browser/credentials/azureCliCredential.d.ts +13 -0
  29. package/dist/browser/credentials/azureCliCredential.js +23 -0
  30. package/dist/browser/credentials/azureCliCredentialOptions.d.ts +20 -0
  31. package/dist/browser/credentials/azureCliCredentialOptions.d.ts.map +1 -0
  32. package/dist/browser/credentials/azureCliCredentialOptions.js.map +1 -0
  33. package/dist/browser/credentials/azureDeveloperCliCredential-browser.d.mts.map +1 -0
  34. package/dist/browser/credentials/azureDeveloperCliCredential-browser.mjs.map +1 -0
  35. package/dist/browser/credentials/azureDeveloperCliCredential.d.ts +13 -0
  36. package/dist/browser/credentials/azureDeveloperCliCredential.js +23 -0
  37. package/dist/browser/credentials/azureDeveloperCliCredentialOptions.d.ts +15 -0
  38. package/dist/browser/credentials/azureDeveloperCliCredentialOptions.d.ts.map +1 -0
  39. package/dist/browser/credentials/azureDeveloperCliCredentialOptions.js.map +1 -0
  40. package/dist/browser/credentials/azurePipelinesCredential-browser.d.mts.map +1 -0
  41. package/dist/browser/credentials/azurePipelinesCredential-browser.mjs.map +1 -0
  42. package/dist/browser/credentials/azurePipelinesCredential.d.ts +13 -0
  43. package/dist/browser/credentials/azurePipelinesCredential.js +23 -0
  44. package/dist/browser/credentials/azurePipelinesCredentialOptions.d.ts +9 -0
  45. package/dist/browser/credentials/azurePipelinesCredentialOptions.d.ts.map +1 -0
  46. package/dist/browser/credentials/azurePipelinesCredentialOptions.js.map +1 -0
  47. package/dist/browser/credentials/azurePowerShellCredential-browser.d.mts.map +1 -0
  48. package/dist/browser/credentials/azurePowerShellCredential-browser.mjs.map +1 -0
  49. package/dist/browser/credentials/azurePowerShellCredential.d.ts +12 -0
  50. package/dist/browser/credentials/azurePowerShellCredential.js +22 -0
  51. package/dist/browser/credentials/azurePowerShellCredentialOptions.d.ts +15 -0
  52. package/dist/browser/credentials/azurePowerShellCredentialOptions.d.ts.map +1 -0
  53. package/dist/browser/credentials/azurePowerShellCredentialOptions.js.map +1 -0
  54. package/dist/browser/credentials/brokerAuthOptions.d.ts +13 -0
  55. package/dist/browser/credentials/brokerAuthOptions.d.ts.map +1 -0
  56. package/dist/browser/credentials/brokerAuthOptions.js.map +1 -0
  57. package/dist/browser/credentials/browserCustomizationOptions.d.ts +19 -0
  58. package/dist/browser/credentials/browserCustomizationOptions.d.ts.map +1 -0
  59. package/dist/browser/credentials/chainedTokenCredential.d.ts +51 -0
  60. package/dist/browser/credentials/chainedTokenCredential.d.ts.map +1 -0
  61. package/dist/browser/credentials/chainedTokenCredential.js +92 -0
  62. package/dist/browser/credentials/chainedTokenCredential.js.map +1 -0
  63. package/dist/browser/credentials/clientAssertionCredential-browser.d.mts.map +1 -0
  64. package/dist/browser/credentials/clientAssertionCredential-browser.mjs.map +1 -0
  65. package/dist/browser/credentials/clientAssertionCredential.d.ts +12 -0
  66. package/dist/browser/credentials/clientAssertionCredential.js +22 -0
  67. package/dist/browser/credentials/clientAssertionCredentialOptions.d.ts +9 -0
  68. package/dist/browser/credentials/clientAssertionCredentialOptions.d.ts.map +1 -0
  69. package/dist/browser/credentials/clientAssertionCredentialOptions.js.map +1 -0
  70. package/dist/browser/credentials/clientCertificateCredential-browser.d.mts.map +1 -0
  71. package/dist/browser/credentials/clientCertificateCredential-browser.mjs.map +1 -0
  72. package/dist/browser/credentials/clientCertificateCredential.d.ts +13 -0
  73. package/dist/browser/credentials/clientCertificateCredential.js +23 -0
  74. package/dist/browser/credentials/clientCertificateCredentialModels.d.ts +31 -0
  75. package/dist/browser/credentials/clientCertificateCredentialModels.d.ts.map +1 -0
  76. package/dist/browser/credentials/clientCertificateCredentialModels.js +4 -0
  77. package/dist/browser/credentials/clientCertificateCredentialModels.js.map +1 -0
  78. package/dist/browser/credentials/clientCertificateCredentialOptions.d.ts +14 -0
  79. package/dist/browser/credentials/clientCertificateCredentialOptions.d.ts.map +1 -0
  80. package/dist/browser/credentials/clientCertificateCredentialOptions.js.map +1 -0
  81. package/dist/browser/credentials/clientSecretCredential-browser.d.mts.map +1 -0
  82. package/dist/browser/credentials/clientSecretCredential-browser.mjs.map +1 -0
  83. package/dist/browser/credentials/clientSecretCredential.d.ts +40 -0
  84. package/dist/browser/credentials/clientSecretCredential.js +83 -0
  85. package/dist/browser/credentials/clientSecretCredentialOptions.d.ts +9 -0
  86. package/dist/browser/credentials/clientSecretCredentialOptions.d.ts.map +1 -0
  87. package/dist/browser/credentials/clientSecretCredentialOptions.js.map +1 -0
  88. package/dist/browser/credentials/credentialPersistenceOptions.d.ts +30 -0
  89. package/dist/browser/credentials/credentialPersistenceOptions.d.ts.map +1 -0
  90. package/dist/browser/credentials/credentialPersistenceOptions.js.map +1 -0
  91. package/dist/browser/credentials/defaultAzureCredential-browser.d.mts.map +1 -0
  92. package/dist/browser/credentials/defaultAzureCredential-browser.mjs.map +1 -0
  93. package/dist/browser/credentials/defaultAzureCredential.d.ts +19 -0
  94. package/dist/browser/credentials/defaultAzureCredential.js +29 -0
  95. package/dist/browser/credentials/defaultAzureCredentialOptions.d.ts +49 -0
  96. package/dist/browser/credentials/defaultAzureCredentialOptions.d.ts.map +1 -0
  97. package/dist/browser/credentials/defaultAzureCredentialOptions.js.map +1 -0
  98. package/dist/browser/credentials/deviceCodeCredential-browser.d.mts.map +1 -0
  99. package/dist/browser/credentials/deviceCodeCredential-browser.mjs.map +1 -0
  100. package/dist/browser/credentials/deviceCodeCredential.d.ts +13 -0
  101. package/dist/browser/credentials/deviceCodeCredential.js +23 -0
  102. package/dist/browser/credentials/deviceCodeCredentialOptions.d.ts +53 -0
  103. package/dist/browser/credentials/deviceCodeCredentialOptions.d.ts.map +1 -0
  104. package/dist/browser/credentials/deviceCodeCredentialOptions.js.map +1 -0
  105. package/dist/browser/credentials/environmentCredential-browser.d.mts.map +1 -0
  106. package/dist/browser/credentials/environmentCredential-browser.mjs.map +1 -0
  107. package/dist/browser/credentials/environmentCredential.d.ts +13 -0
  108. package/dist/browser/credentials/environmentCredential.js +23 -0
  109. package/dist/browser/credentials/environmentCredentialOptions.d.ts +9 -0
  110. package/dist/browser/credentials/environmentCredentialOptions.d.ts.map +1 -0
  111. package/dist/browser/credentials/environmentCredentialOptions.js.map +1 -0
  112. package/dist/browser/credentials/interactiveBrowserCredential-browser.d.mts.map +1 -0
  113. package/dist/browser/credentials/interactiveBrowserCredential-browser.mjs.map +1 -0
  114. package/dist/browser/credentials/interactiveBrowserCredential.d.ts +53 -0
  115. package/dist/browser/credentials/interactiveBrowserCredential.js +86 -0
  116. package/dist/browser/credentials/interactiveBrowserCredentialOptions.d.ts +77 -0
  117. package/dist/browser/credentials/interactiveBrowserCredentialOptions.d.ts.map +1 -0
  118. package/dist/browser/credentials/interactiveBrowserCredentialOptions.js.map +1 -0
  119. package/dist/browser/credentials/interactiveCredentialOptions.d.ts +25 -0
  120. package/dist/browser/credentials/interactiveCredentialOptions.d.ts.map +1 -0
  121. package/dist/browser/credentials/interactiveCredentialOptions.js.map +1 -0
  122. package/dist/browser/credentials/managedIdentityCredential/imdsMsi.d.ts +18 -0
  123. package/dist/browser/credentials/managedIdentityCredential/imdsMsi.d.ts.map +1 -0
  124. package/dist/browser/credentials/managedIdentityCredential/imdsMsi.js +122 -0
  125. package/dist/browser/credentials/managedIdentityCredential/imdsMsi.js.map +1 -0
  126. package/dist/browser/credentials/managedIdentityCredential/imdsRetryPolicy.d.ts +12 -0
  127. package/dist/browser/credentials/managedIdentityCredential/imdsRetryPolicy.d.ts.map +1 -0
  128. package/dist/browser/credentials/managedIdentityCredential/imdsRetryPolicy.js.map +1 -0
  129. package/dist/browser/credentials/managedIdentityCredential/index-browser.d.mts.map +1 -0
  130. package/dist/browser/credentials/managedIdentityCredential/index-browser.mjs.map +1 -0
  131. package/dist/browser/credentials/managedIdentityCredential/index.d.ts +6 -0
  132. package/dist/browser/credentials/managedIdentityCredential/index.js +16 -0
  133. package/dist/browser/credentials/managedIdentityCredential/models.d.ts +24 -0
  134. package/dist/browser/credentials/managedIdentityCredential/models.d.ts.map +1 -0
  135. package/dist/browser/credentials/managedIdentityCredential/models.js.map +1 -0
  136. package/dist/browser/credentials/managedIdentityCredential/options.d.ts +37 -0
  137. package/dist/browser/credentials/managedIdentityCredential/options.d.ts.map +1 -0
  138. package/dist/browser/credentials/managedIdentityCredential/options.js +4 -0
  139. package/dist/browser/credentials/managedIdentityCredential/options.js.map +1 -0
  140. package/dist/browser/credentials/managedIdentityCredential/tokenExchangeMsi.d.ts +14 -0
  141. package/dist/browser/credentials/managedIdentityCredential/tokenExchangeMsi.d.ts.map +1 -0
  142. package/dist/browser/credentials/managedIdentityCredential/tokenExchangeMsi.js +32 -0
  143. package/dist/browser/credentials/managedIdentityCredential/tokenExchangeMsi.js.map +1 -0
  144. package/dist/browser/credentials/managedIdentityCredential/utils.d.ts +33 -0
  145. package/dist/browser/credentials/managedIdentityCredential/utils.d.ts.map +1 -0
  146. package/dist/browser/credentials/managedIdentityCredential/utils.js +77 -0
  147. package/dist/browser/credentials/managedIdentityCredential/utils.js.map +1 -0
  148. package/dist/browser/credentials/multiTenantTokenCredentialOptions.d.ts +12 -0
  149. package/dist/browser/credentials/multiTenantTokenCredentialOptions.d.ts.map +1 -0
  150. package/dist/browser/credentials/multiTenantTokenCredentialOptions.js.map +1 -0
  151. package/dist/browser/credentials/onBehalfOfCredential-browser.d.mts.map +1 -0
  152. package/dist/browser/credentials/onBehalfOfCredential-browser.mjs.map +1 -0
  153. package/dist/browser/credentials/onBehalfOfCredential.d.ts +12 -0
  154. package/dist/browser/credentials/onBehalfOfCredential.js +23 -0
  155. package/dist/browser/credentials/onBehalfOfCredentialOptions.d.ts +76 -0
  156. package/dist/browser/credentials/onBehalfOfCredentialOptions.d.ts.map +1 -0
  157. package/dist/browser/credentials/onBehalfOfCredentialOptions.js.map +1 -0
  158. package/dist/browser/credentials/usernamePasswordCredential-browser.d.mts.map +1 -0
  159. package/dist/browser/credentials/usernamePasswordCredential-browser.mjs.map +1 -0
  160. package/dist/browser/credentials/usernamePasswordCredential.d.ts +40 -0
  161. package/dist/browser/credentials/usernamePasswordCredential.js +77 -0
  162. package/dist/browser/credentials/usernamePasswordCredentialOptions.d.ts +9 -0
  163. package/dist/browser/credentials/usernamePasswordCredentialOptions.d.ts.map +1 -0
  164. package/dist/browser/credentials/usernamePasswordCredentialOptions.js.map +1 -0
  165. package/dist/browser/credentials/visualStudioCodeCredential-browser.d.mts.map +1 -0
  166. package/dist/browser/credentials/visualStudioCodeCredential-browser.mjs.map +1 -0
  167. package/dist/browser/credentials/visualStudioCodeCredential.d.ts +15 -0
  168. package/dist/browser/credentials/visualStudioCodeCredential.js +27 -0
  169. package/dist/browser/credentials/visualStudioCodeCredentialOptions.d.ts +11 -0
  170. package/dist/browser/credentials/visualStudioCodeCredentialOptions.d.ts.map +1 -0
  171. package/dist/browser/credentials/visualStudioCodeCredentialOptions.js.map +1 -0
  172. package/dist/browser/credentials/visualStudioCodeCredentialPlugin.d.ts +11 -0
  173. package/dist/browser/credentials/visualStudioCodeCredentialPlugin.d.ts.map +1 -0
  174. package/dist/browser/credentials/workloadIdentityCredential-browser.d.mts.map +1 -0
  175. package/dist/browser/credentials/workloadIdentityCredential-browser.mjs.map +1 -0
  176. package/dist/browser/credentials/workloadIdentityCredential.d.ts +17 -0
  177. package/dist/browser/credentials/workloadIdentityCredential.js +27 -0
  178. package/dist/browser/credentials/workloadIdentityCredentialOptions.d.ts +20 -0
  179. package/dist/browser/credentials/workloadIdentityCredentialOptions.d.ts.map +1 -0
  180. package/dist/browser/credentials/workloadIdentityCredentialOptions.js.map +1 -0
  181. package/dist/browser/errors.d.ts +139 -0
  182. package/dist/browser/errors.d.ts.map +1 -0
  183. package/dist/browser/errors.js.map +1 -0
  184. package/dist/browser/index.d.ts +61 -0
  185. package/dist/browser/index.d.ts.map +1 -0
  186. package/dist/browser/index.js +34 -0
  187. package/dist/browser/index.js.map +1 -0
  188. package/dist/browser/msal/browserFlows/flows.d.ts +42 -0
  189. package/dist/browser/msal/browserFlows/flows.d.ts.map +1 -0
  190. package/dist/browser/msal/browserFlows/flows.js.map +1 -0
  191. package/dist/browser/msal/browserFlows/msalAuthCode.d.ts +48 -0
  192. package/dist/browser/msal/browserFlows/msalAuthCode.d.ts.map +1 -0
  193. package/dist/browser/msal/browserFlows/msalAuthCode.js +203 -0
  194. package/dist/browser/msal/browserFlows/msalAuthCode.js.map +1 -0
  195. package/dist/browser/msal/browserFlows/msalBrowserCommon.d.ts +106 -0
  196. package/dist/browser/msal/browserFlows/msalBrowserCommon.d.ts.map +1 -0
  197. package/dist/browser/msal/browserFlows/msalBrowserCommon.js +116 -0
  198. package/dist/browser/msal/browserFlows/msalBrowserCommon.js.map +1 -0
  199. package/dist/browser/msal/credentials.d.ts +52 -0
  200. package/dist/browser/msal/credentials.d.ts.map +1 -0
  201. package/dist/browser/msal/credentials.js.map +1 -0
  202. package/dist/browser/msal/msal-browser.d.mts.map +1 -0
  203. package/dist/browser/msal/msal-browser.mjs.map +1 -0
  204. package/dist/browser/msal/msal.d.ts +3 -0
  205. package/dist/browser/msal/msal.js +5 -0
  206. package/dist/browser/msal/nodeFlows/brokerOptions.d.ts +44 -0
  207. package/dist/browser/msal/nodeFlows/brokerOptions.d.ts.map +1 -0
  208. package/dist/browser/msal/nodeFlows/msalClient.d.ts +186 -0
  209. package/dist/browser/msal/nodeFlows/msalClient.d.ts.map +1 -0
  210. package/dist/browser/msal/nodeFlows/msalClient.js +477 -0
  211. package/dist/browser/msal/nodeFlows/msalClient.js.map +1 -0
  212. package/dist/browser/msal/nodeFlows/msalPlugins.d.ts +91 -0
  213. package/dist/browser/msal/nodeFlows/msalPlugins.d.ts.map +1 -0
  214. package/dist/browser/msal/nodeFlows/msalPlugins.js +87 -0
  215. package/dist/browser/msal/nodeFlows/msalPlugins.js.map +1 -0
  216. package/dist/browser/msal/nodeFlows/tokenCachePersistenceOptions.d.ts +24 -0
  217. package/dist/browser/msal/nodeFlows/tokenCachePersistenceOptions.d.ts.map +1 -0
  218. package/dist/browser/msal/types.d.ts +87 -0
  219. package/dist/browser/msal/types.d.ts.map +1 -0
  220. package/dist/browser/msal/types.js.map +1 -0
  221. package/dist/browser/msal/utils.d.ts +95 -0
  222. package/dist/browser/msal/utils.d.ts.map +1 -0
  223. package/dist/browser/msal/utils.js +238 -0
  224. package/dist/browser/msal/utils.js.map +1 -0
  225. package/dist/browser/package.json +3 -0
  226. package/dist/browser/plugins/consumer-browser.d.mts.map +1 -0
  227. package/dist/browser/plugins/consumer-browser.mjs.map +1 -0
  228. package/dist/browser/plugins/consumer.d.ts +2 -0
  229. package/dist/browser/plugins/consumer.js +7 -0
  230. package/dist/browser/plugins/provider.d.ts +36 -0
  231. package/dist/browser/plugins/provider.d.ts.map +1 -0
  232. package/dist/browser/plugins/provider.js.map +1 -0
  233. package/dist/browser/regionalAuthority.d.ts +122 -0
  234. package/dist/browser/regionalAuthority.d.ts.map +1 -0
  235. package/dist/browser/tokenCredentialOptions.d.ts +28 -0
  236. package/dist/browser/tokenCredentialOptions.d.ts.map +1 -0
  237. package/dist/browser/tokenCredentialOptions.js.map +1 -0
  238. package/dist/browser/tokenProvider.d.ts +39 -0
  239. package/dist/browser/tokenProvider.d.ts.map +1 -0
  240. package/dist/browser/tokenProvider.js +53 -0
  241. package/dist/browser/tokenProvider.js.map +1 -0
  242. package/dist/browser/util/authHostEnv-browser.d.mts +4 -0
  243. package/dist/browser/util/authHostEnv-browser.d.mts.map +1 -0
  244. package/dist/browser/util/authHostEnv-browser.mjs +7 -0
  245. package/dist/browser/util/authHostEnv-browser.mjs.map +1 -0
  246. package/dist/browser/util/identityTokenEndpoint.d.ts +2 -0
  247. package/dist/browser/util/identityTokenEndpoint.d.ts.map +1 -0
  248. package/dist/browser/util/logging.d.ts +70 -0
  249. package/dist/browser/util/logging.d.ts.map +1 -0
  250. package/dist/browser/util/logging.js.map +1 -0
  251. package/dist/browser/util/processMultiTenantRequest-browser.d.mts.map +1 -0
  252. package/dist/browser/util/processMultiTenantRequest-browser.mjs.map +1 -0
  253. package/dist/browser/util/processMultiTenantRequest.d.ts +9 -0
  254. package/dist/browser/util/processMultiTenantRequest.js +29 -0
  255. package/dist/browser/util/processUtils.d.ts +13 -0
  256. package/dist/browser/util/processUtils.d.ts.map +1 -0
  257. package/dist/browser/util/scopeUtils.d.ts +17 -0
  258. package/dist/browser/util/scopeUtils.d.ts.map +1 -0
  259. package/dist/browser/util/scopeUtils.js +29 -0
  260. package/dist/browser/util/scopeUtils.js.map +1 -0
  261. package/dist/browser/util/subscriptionUtils.d.ts +6 -0
  262. package/dist/browser/util/subscriptionUtils.d.ts.map +1 -0
  263. package/dist/browser/util/subscriptionUtils.js +14 -0
  264. package/dist/browser/util/subscriptionUtils.js.map +1 -0
  265. package/dist/browser/util/tenantIdUtils.d.ts +15 -0
  266. package/dist/browser/util/tenantIdUtils.d.ts.map +1 -0
  267. package/dist/browser/util/tenantIdUtils.js +44 -0
  268. package/dist/browser/util/tenantIdUtils.js.map +1 -0
  269. package/dist/browser/util/tracing.d.ts +6 -0
  270. package/dist/browser/util/tracing.d.ts.map +1 -0
  271. package/dist/browser/util/tracing.js +14 -0
  272. package/dist/browser/util/tracing.js.map +1 -0
  273. package/dist/commonjs/client/identityClient.d.ts +65 -0
  274. package/dist/commonjs/client/identityClient.d.ts.map +1 -0
  275. package/dist/commonjs/client/identityClient.js +253 -0
  276. package/dist/commonjs/client/identityClient.js.map +1 -0
  277. package/dist/commonjs/constants.d.ts +69 -0
  278. package/dist/commonjs/constants.d.ts.map +1 -0
  279. package/dist/commonjs/constants.js +78 -0
  280. package/dist/commonjs/constants.js.map +1 -0
  281. package/dist/commonjs/credentials/authorityValidationOptions.d.ts +16 -0
  282. package/dist/commonjs/credentials/authorityValidationOptions.d.ts.map +1 -0
  283. package/dist/commonjs/credentials/authorityValidationOptions.js +5 -0
  284. package/dist/commonjs/credentials/authorityValidationOptions.js.map +1 -0
  285. package/dist/commonjs/credentials/authorizationCodeCredential.d.ts +73 -0
  286. package/dist/commonjs/credentials/authorizationCodeCredential.d.ts.map +1 -0
  287. package/dist/commonjs/credentials/authorizationCodeCredential.js +64 -0
  288. package/dist/commonjs/credentials/authorizationCodeCredential.js.map +1 -0
  289. package/dist/commonjs/credentials/authorizationCodeCredentialOptions.d.ts +8 -0
  290. package/dist/commonjs/credentials/authorizationCodeCredentialOptions.d.ts.map +1 -0
  291. package/dist/commonjs/credentials/authorizationCodeCredentialOptions.js +5 -0
  292. package/dist/commonjs/credentials/authorizationCodeCredentialOptions.js.map +1 -0
  293. package/dist/commonjs/credentials/azureApplicationCredential.d.ts +24 -0
  294. package/dist/commonjs/credentials/azureApplicationCredential.d.ts.map +1 -0
  295. package/dist/commonjs/credentials/azureApplicationCredential.js +36 -0
  296. package/dist/commonjs/credentials/azureApplicationCredential.js.map +1 -0
  297. package/dist/commonjs/credentials/azureApplicationCredentialOptions.d.ts +13 -0
  298. package/dist/commonjs/credentials/azureApplicationCredentialOptions.d.ts.map +1 -0
  299. package/dist/commonjs/credentials/azureApplicationCredentialOptions.js +5 -0
  300. package/dist/commonjs/credentials/azureApplicationCredentialOptions.js.map +1 -0
  301. package/dist/commonjs/credentials/azureCliCredential.d.ts +64 -0
  302. package/dist/commonjs/credentials/azureCliCredential.d.ts.map +1 -0
  303. package/dist/commonjs/credentials/azureCliCredential.js +194 -0
  304. package/dist/commonjs/credentials/azureCliCredential.js.map +1 -0
  305. package/dist/commonjs/credentials/azureCliCredentialOptions.d.ts +20 -0
  306. package/dist/commonjs/credentials/azureCliCredentialOptions.d.ts.map +1 -0
  307. package/dist/commonjs/credentials/azureCliCredentialOptions.js +5 -0
  308. package/dist/commonjs/credentials/azureCliCredentialOptions.js.map +1 -0
  309. package/dist/commonjs/credentials/azureDeveloperCliCredential.d.ts +71 -0
  310. package/dist/commonjs/credentials/azureDeveloperCliCredential.d.ts.map +1 -0
  311. package/dist/commonjs/credentials/azureDeveloperCliCredential.js +176 -0
  312. package/dist/commonjs/credentials/azureDeveloperCliCredential.js.map +1 -0
  313. package/dist/commonjs/credentials/azureDeveloperCliCredentialOptions.d.ts +15 -0
  314. package/dist/commonjs/credentials/azureDeveloperCliCredentialOptions.d.ts.map +1 -0
  315. package/dist/commonjs/credentials/azureDeveloperCliCredentialOptions.js +5 -0
  316. package/dist/commonjs/credentials/azureDeveloperCliCredentialOptions.js.map +1 -0
  317. package/dist/commonjs/credentials/azurePipelinesCredential.d.ts +38 -0
  318. package/dist/commonjs/credentials/azurePipelinesCredential.d.ts.map +1 -0
  319. package/dist/commonjs/credentials/azurePipelinesCredential.js +146 -0
  320. package/dist/commonjs/credentials/azurePipelinesCredential.js.map +1 -0
  321. package/dist/commonjs/credentials/azurePipelinesCredentialOptions.d.ts +9 -0
  322. package/dist/commonjs/credentials/azurePipelinesCredentialOptions.d.ts.map +1 -0
  323. package/dist/commonjs/credentials/azurePipelinesCredentialOptions.js +5 -0
  324. package/dist/commonjs/credentials/azurePipelinesCredentialOptions.js.map +1 -0
  325. package/dist/commonjs/credentials/azurePowerShellCredential.d.ts +75 -0
  326. package/dist/commonjs/credentials/azurePowerShellCredential.d.ts.map +1 -0
  327. package/dist/commonjs/credentials/azurePowerShellCredential.js +235 -0
  328. package/dist/commonjs/credentials/azurePowerShellCredential.js.map +1 -0
  329. package/dist/commonjs/credentials/azurePowerShellCredentialOptions.d.ts +15 -0
  330. package/dist/commonjs/credentials/azurePowerShellCredentialOptions.d.ts.map +1 -0
  331. package/dist/commonjs/credentials/azurePowerShellCredentialOptions.js +5 -0
  332. package/dist/commonjs/credentials/azurePowerShellCredentialOptions.js.map +1 -0
  333. package/dist/commonjs/credentials/brokerAuthOptions.d.ts +13 -0
  334. package/dist/commonjs/credentials/brokerAuthOptions.d.ts.map +1 -0
  335. package/dist/commonjs/credentials/brokerAuthOptions.js +3 -0
  336. package/dist/commonjs/credentials/brokerAuthOptions.js.map +1 -0
  337. package/dist/commonjs/credentials/browserCustomizationOptions.d.ts +19 -0
  338. package/dist/commonjs/credentials/browserCustomizationOptions.d.ts.map +1 -0
  339. package/dist/commonjs/credentials/browserCustomizationOptions.js +5 -0
  340. package/dist/commonjs/credentials/browserCustomizationOptions.js.map +1 -0
  341. package/dist/commonjs/credentials/chainedTokenCredential.d.ts +51 -0
  342. package/dist/commonjs/credentials/chainedTokenCredential.d.ts.map +1 -0
  343. package/dist/commonjs/credentials/chainedTokenCredential.js +96 -0
  344. package/dist/commonjs/credentials/chainedTokenCredential.js.map +1 -0
  345. package/dist/commonjs/credentials/clientAssertionCredential.d.ts +33 -0
  346. package/dist/commonjs/credentials/clientAssertionCredential.d.ts.map +1 -0
  347. package/dist/commonjs/credentials/clientAssertionCredential.js +59 -0
  348. package/dist/commonjs/credentials/clientAssertionCredential.js.map +1 -0
  349. package/dist/commonjs/credentials/clientAssertionCredentialOptions.d.ts +9 -0
  350. package/dist/commonjs/credentials/clientAssertionCredentialOptions.d.ts.map +1 -0
  351. package/dist/commonjs/credentials/clientAssertionCredentialOptions.js +5 -0
  352. package/dist/commonjs/credentials/clientAssertionCredentialOptions.js.map +1 -0
  353. package/dist/commonjs/credentials/clientCertificateCredential.d.ts +72 -0
  354. package/dist/commonjs/credentials/clientCertificateCredential.d.ts.map +1 -0
  355. package/dist/commonjs/credentials/clientCertificateCredential.js +127 -0
  356. package/dist/commonjs/credentials/clientCertificateCredential.js.map +1 -0
  357. package/dist/commonjs/credentials/clientCertificateCredentialModels.d.ts +31 -0
  358. package/dist/commonjs/credentials/clientCertificateCredentialModels.d.ts.map +1 -0
  359. package/dist/commonjs/credentials/clientCertificateCredentialModels.js +5 -0
  360. package/dist/commonjs/credentials/clientCertificateCredentialModels.js.map +1 -0
  361. package/dist/commonjs/credentials/clientCertificateCredentialOptions.d.ts +14 -0
  362. package/dist/commonjs/credentials/clientCertificateCredentialOptions.d.ts.map +1 -0
  363. package/dist/commonjs/credentials/clientCertificateCredentialOptions.js +5 -0
  364. package/dist/commonjs/credentials/clientCertificateCredentialOptions.js.map +1 -0
  365. package/dist/commonjs/credentials/clientSecretCredential.d.ts +37 -0
  366. package/dist/commonjs/credentials/clientSecretCredential.d.ts.map +1 -0
  367. package/dist/commonjs/credentials/clientSecretCredential.js +64 -0
  368. package/dist/commonjs/credentials/clientSecretCredential.js.map +1 -0
  369. package/dist/commonjs/credentials/clientSecretCredentialOptions.d.ts +9 -0
  370. package/dist/commonjs/credentials/clientSecretCredentialOptions.d.ts.map +1 -0
  371. package/dist/commonjs/credentials/clientSecretCredentialOptions.js +5 -0
  372. package/dist/commonjs/credentials/clientSecretCredentialOptions.js.map +1 -0
  373. package/dist/commonjs/credentials/credentialPersistenceOptions.d.ts +30 -0
  374. package/dist/commonjs/credentials/credentialPersistenceOptions.d.ts.map +1 -0
  375. package/dist/commonjs/credentials/credentialPersistenceOptions.js +5 -0
  376. package/dist/commonjs/credentials/credentialPersistenceOptions.js.map +1 -0
  377. package/dist/commonjs/credentials/defaultAzureCredential.d.ts +65 -0
  378. package/dist/commonjs/credentials/defaultAzureCredential.d.ts.map +1 -0
  379. package/dist/commonjs/credentials/defaultAzureCredential.js +171 -0
  380. package/dist/commonjs/credentials/defaultAzureCredential.js.map +1 -0
  381. package/dist/commonjs/credentials/defaultAzureCredentialOptions.d.ts +49 -0
  382. package/dist/commonjs/credentials/defaultAzureCredentialOptions.d.ts.map +1 -0
  383. package/dist/commonjs/credentials/defaultAzureCredentialOptions.js +5 -0
  384. package/dist/commonjs/credentials/defaultAzureCredentialOptions.js.map +1 -0
  385. package/dist/commonjs/credentials/deviceCodeCredential.d.ts +67 -0
  386. package/dist/commonjs/credentials/deviceCodeCredential.d.ts.map +1 -0
  387. package/dist/commonjs/credentials/deviceCodeCredential.js +96 -0
  388. package/dist/commonjs/credentials/deviceCodeCredential.js.map +1 -0
  389. package/dist/commonjs/credentials/deviceCodeCredentialOptions.d.ts +53 -0
  390. package/dist/commonjs/credentials/deviceCodeCredentialOptions.d.ts.map +1 -0
  391. package/dist/commonjs/credentials/deviceCodeCredentialOptions.js +5 -0
  392. package/dist/commonjs/credentials/deviceCodeCredentialOptions.js.map +1 -0
  393. package/dist/commonjs/credentials/environmentCredential.d.ts +52 -0
  394. package/dist/commonjs/credentials/environmentCredential.d.ts.map +1 -0
  395. package/dist/commonjs/credentials/environmentCredential.js +135 -0
  396. package/dist/commonjs/credentials/environmentCredential.js.map +1 -0
  397. package/dist/commonjs/credentials/environmentCredentialOptions.d.ts +9 -0
  398. package/dist/commonjs/credentials/environmentCredentialOptions.d.ts.map +1 -0
  399. package/dist/commonjs/credentials/environmentCredentialOptions.js +5 -0
  400. package/dist/commonjs/credentials/environmentCredentialOptions.js.map +1 -0
  401. package/dist/commonjs/credentials/interactiveBrowserCredential.d.ts +56 -0
  402. package/dist/commonjs/credentials/interactiveBrowserCredential.d.ts.map +1 -0
  403. package/dist/commonjs/credentials/interactiveBrowserCredential.js +95 -0
  404. package/dist/commonjs/credentials/interactiveBrowserCredential.js.map +1 -0
  405. package/dist/commonjs/credentials/interactiveBrowserCredentialOptions.d.ts +77 -0
  406. package/dist/commonjs/credentials/interactiveBrowserCredentialOptions.d.ts.map +1 -0
  407. package/dist/commonjs/credentials/interactiveBrowserCredentialOptions.js +5 -0
  408. package/dist/commonjs/credentials/interactiveBrowserCredentialOptions.js.map +1 -0
  409. package/dist/commonjs/credentials/interactiveCredentialOptions.d.ts +25 -0
  410. package/dist/commonjs/credentials/interactiveCredentialOptions.d.ts.map +1 -0
  411. package/dist/commonjs/credentials/interactiveCredentialOptions.js +5 -0
  412. package/dist/commonjs/credentials/interactiveCredentialOptions.js.map +1 -0
  413. package/dist/commonjs/credentials/managedIdentityCredential/imdsMsi.d.ts +18 -0
  414. package/dist/commonjs/credentials/managedIdentityCredential/imdsMsi.d.ts.map +1 -0
  415. package/dist/commonjs/credentials/managedIdentityCredential/imdsMsi.js +125 -0
  416. package/dist/commonjs/credentials/managedIdentityCredential/imdsMsi.js.map +1 -0
  417. package/dist/commonjs/credentials/managedIdentityCredential/imdsRetryPolicy.d.ts +12 -0
  418. package/dist/commonjs/credentials/managedIdentityCredential/imdsRetryPolicy.d.ts.map +1 -0
  419. package/dist/commonjs/credentials/managedIdentityCredential/imdsRetryPolicy.js +36 -0
  420. package/dist/commonjs/credentials/managedIdentityCredential/imdsRetryPolicy.js.map +1 -0
  421. package/dist/commonjs/credentials/managedIdentityCredential/index.d.ts +61 -0
  422. package/dist/commonjs/credentials/managedIdentityCredential/index.d.ts.map +1 -0
  423. package/dist/commonjs/credentials/managedIdentityCredential/index.js +221 -0
  424. package/dist/commonjs/credentials/managedIdentityCredential/index.js.map +1 -0
  425. package/dist/commonjs/credentials/managedIdentityCredential/models.d.ts +24 -0
  426. package/dist/commonjs/credentials/managedIdentityCredential/models.d.ts.map +1 -0
  427. package/dist/commonjs/credentials/managedIdentityCredential/models.js +5 -0
  428. package/dist/commonjs/credentials/managedIdentityCredential/models.js.map +1 -0
  429. package/dist/commonjs/credentials/managedIdentityCredential/options.d.ts +37 -0
  430. package/dist/commonjs/credentials/managedIdentityCredential/options.d.ts.map +1 -0
  431. package/dist/commonjs/credentials/managedIdentityCredential/options.js +5 -0
  432. package/dist/commonjs/credentials/managedIdentityCredential/options.js.map +1 -0
  433. package/dist/commonjs/credentials/managedIdentityCredential/tokenExchangeMsi.d.ts +14 -0
  434. package/dist/commonjs/credentials/managedIdentityCredential/tokenExchangeMsi.d.ts.map +1 -0
  435. package/dist/commonjs/credentials/managedIdentityCredential/tokenExchangeMsi.js +35 -0
  436. package/dist/commonjs/credentials/managedIdentityCredential/tokenExchangeMsi.js.map +1 -0
  437. package/dist/commonjs/credentials/managedIdentityCredential/utils.d.ts +33 -0
  438. package/dist/commonjs/credentials/managedIdentityCredential/utils.d.ts.map +1 -0
  439. package/dist/commonjs/credentials/managedIdentityCredential/utils.js +82 -0
  440. package/dist/commonjs/credentials/managedIdentityCredential/utils.js.map +1 -0
  441. package/dist/commonjs/credentials/multiTenantTokenCredentialOptions.d.ts +12 -0
  442. package/dist/commonjs/credentials/multiTenantTokenCredentialOptions.d.ts.map +1 -0
  443. package/dist/commonjs/credentials/multiTenantTokenCredentialOptions.js +5 -0
  444. package/dist/commonjs/credentials/multiTenantTokenCredentialOptions.js.map +1 -0
  445. package/dist/commonjs/credentials/onBehalfOfCredential.d.ts +105 -0
  446. package/dist/commonjs/credentials/onBehalfOfCredential.d.ts.map +1 -0
  447. package/dist/commonjs/credentials/onBehalfOfCredential.js +116 -0
  448. package/dist/commonjs/credentials/onBehalfOfCredential.js.map +1 -0
  449. package/dist/commonjs/credentials/onBehalfOfCredentialOptions.d.ts +76 -0
  450. package/dist/commonjs/credentials/onBehalfOfCredentialOptions.d.ts.map +1 -0
  451. package/dist/commonjs/credentials/onBehalfOfCredentialOptions.js +5 -0
  452. package/dist/commonjs/credentials/onBehalfOfCredentialOptions.js.map +1 -0
  453. package/dist/commonjs/credentials/usernamePasswordCredential.d.ts +41 -0
  454. package/dist/commonjs/credentials/usernamePasswordCredential.d.ts.map +1 -0
  455. package/dist/commonjs/credentials/usernamePasswordCredential.js +71 -0
  456. package/dist/commonjs/credentials/usernamePasswordCredential.js.map +1 -0
  457. package/dist/commonjs/credentials/usernamePasswordCredentialOptions.d.ts +9 -0
  458. package/dist/commonjs/credentials/usernamePasswordCredentialOptions.d.ts.map +1 -0
  459. package/dist/commonjs/credentials/usernamePasswordCredentialOptions.js +5 -0
  460. package/dist/commonjs/credentials/usernamePasswordCredentialOptions.js.map +1 -0
  461. package/dist/commonjs/credentials/visualStudioCodeCredential.d.ts +60 -0
  462. package/dist/commonjs/credentials/visualStudioCodeCredential.d.ts.map +1 -0
  463. package/dist/commonjs/credentials/visualStudioCodeCredential.js +196 -0
  464. package/dist/commonjs/credentials/visualStudioCodeCredential.js.map +1 -0
  465. package/dist/commonjs/credentials/visualStudioCodeCredentialOptions.d.ts +11 -0
  466. package/dist/commonjs/credentials/visualStudioCodeCredentialOptions.d.ts.map +1 -0
  467. package/dist/commonjs/credentials/visualStudioCodeCredentialOptions.js +5 -0
  468. package/dist/commonjs/credentials/visualStudioCodeCredentialOptions.js.map +1 -0
  469. package/dist/commonjs/credentials/visualStudioCodeCredentialPlugin.d.ts +11 -0
  470. package/dist/commonjs/credentials/visualStudioCodeCredentialPlugin.d.ts.map +1 -0
  471. package/dist/commonjs/credentials/visualStudioCodeCredentialPlugin.js +5 -0
  472. package/dist/commonjs/credentials/visualStudioCodeCredentialPlugin.js.map +1 -0
  473. package/dist/commonjs/credentials/workloadIdentityCredential.d.ts +47 -0
  474. package/dist/commonjs/credentials/workloadIdentityCredential.d.ts.map +1 -0
  475. package/dist/commonjs/credentials/workloadIdentityCredential.js +118 -0
  476. package/dist/commonjs/credentials/workloadIdentityCredential.js.map +1 -0
  477. package/dist/commonjs/credentials/workloadIdentityCredentialOptions.d.ts +20 -0
  478. package/dist/commonjs/credentials/workloadIdentityCredentialOptions.d.ts.map +1 -0
  479. package/dist/commonjs/credentials/workloadIdentityCredentialOptions.js +5 -0
  480. package/dist/commonjs/credentials/workloadIdentityCredentialOptions.js.map +1 -0
  481. package/dist/commonjs/errors.d.ts +139 -0
  482. package/dist/commonjs/errors.d.ts.map +1 -0
  483. package/dist/commonjs/errors.js +130 -0
  484. package/dist/commonjs/errors.js.map +1 -0
  485. package/dist/commonjs/index.d.ts +61 -0
  486. package/dist/commonjs/index.d.ts.map +1 -0
  487. package/dist/commonjs/index.js +69 -0
  488. package/dist/commonjs/index.js.map +1 -0
  489. package/dist/commonjs/msal/browserFlows/flows.d.ts +42 -0
  490. package/dist/commonjs/msal/browserFlows/flows.d.ts.map +1 -0
  491. package/dist/commonjs/msal/browserFlows/flows.js +5 -0
  492. package/dist/commonjs/msal/browserFlows/flows.js.map +1 -0
  493. package/dist/commonjs/msal/browserFlows/msalAuthCode.d.ts +48 -0
  494. package/dist/commonjs/msal/browserFlows/msalAuthCode.d.ts.map +1 -0
  495. package/dist/commonjs/msal/browserFlows/msalAuthCode.js +208 -0
  496. package/dist/commonjs/msal/browserFlows/msalAuthCode.js.map +1 -0
  497. package/dist/commonjs/msal/browserFlows/msalBrowserCommon.d.ts +106 -0
  498. package/dist/commonjs/msal/browserFlows/msalBrowserCommon.d.ts.map +1 -0
  499. package/dist/commonjs/msal/browserFlows/msalBrowserCommon.js +121 -0
  500. package/dist/commonjs/msal/browserFlows/msalBrowserCommon.js.map +1 -0
  501. package/dist/commonjs/msal/credentials.d.ts +52 -0
  502. package/dist/commonjs/msal/credentials.d.ts.map +1 -0
  503. package/dist/commonjs/msal/credentials.js +5 -0
  504. package/dist/commonjs/msal/credentials.js.map +1 -0
  505. package/dist/commonjs/msal/msal.d.ts +3 -0
  506. package/dist/commonjs/msal/msal.d.ts.map +1 -0
  507. package/dist/commonjs/msal/msal.js +9 -0
  508. package/dist/commonjs/msal/msal.js.map +1 -0
  509. package/dist/commonjs/msal/nodeFlows/brokerOptions.d.ts +44 -0
  510. package/dist/commonjs/msal/nodeFlows/brokerOptions.d.ts.map +1 -0
  511. package/dist/commonjs/msal/nodeFlows/brokerOptions.js +3 -0
  512. package/dist/commonjs/msal/nodeFlows/brokerOptions.js.map +1 -0
  513. package/dist/commonjs/msal/nodeFlows/msalClient.d.ts +186 -0
  514. package/dist/commonjs/msal/nodeFlows/msalClient.d.ts.map +1 -0
  515. package/dist/commonjs/msal/nodeFlows/msalClient.js +482 -0
  516. package/dist/commonjs/msal/nodeFlows/msalClient.js.map +1 -0
  517. package/dist/commonjs/msal/nodeFlows/msalPlugins.d.ts +91 -0
  518. package/dist/commonjs/msal/nodeFlows/msalPlugins.d.ts.map +1 -0
  519. package/dist/commonjs/msal/nodeFlows/msalPlugins.js +91 -0
  520. package/dist/commonjs/msal/nodeFlows/msalPlugins.js.map +1 -0
  521. package/dist/commonjs/msal/nodeFlows/tokenCachePersistenceOptions.d.ts +24 -0
  522. package/dist/commonjs/msal/nodeFlows/tokenCachePersistenceOptions.d.ts.map +1 -0
  523. package/dist/commonjs/msal/nodeFlows/tokenCachePersistenceOptions.js +5 -0
  524. package/dist/commonjs/msal/nodeFlows/tokenCachePersistenceOptions.js.map +1 -0
  525. package/dist/commonjs/msal/types.d.ts +87 -0
  526. package/dist/commonjs/msal/types.d.ts.map +1 -0
  527. package/dist/commonjs/msal/types.js +5 -0
  528. package/dist/commonjs/msal/types.js.map +1 -0
  529. package/dist/commonjs/msal/utils.d.ts +95 -0
  530. package/dist/commonjs/msal/utils.d.ts.map +1 -0
  531. package/dist/commonjs/msal/utils.js +253 -0
  532. package/dist/commonjs/msal/utils.js.map +1 -0
  533. package/dist/commonjs/package.json +3 -0
  534. package/dist/commonjs/plugins/consumer.d.ts +28 -0
  535. package/dist/commonjs/plugins/consumer.d.ts.map +1 -0
  536. package/dist/commonjs/plugins/consumer.js +46 -0
  537. package/dist/commonjs/plugins/consumer.js.map +1 -0
  538. package/dist/commonjs/plugins/provider.d.ts +36 -0
  539. package/dist/commonjs/plugins/provider.d.ts.map +1 -0
  540. package/dist/commonjs/plugins/provider.js +5 -0
  541. package/dist/commonjs/plugins/provider.js.map +1 -0
  542. package/dist/commonjs/regionalAuthority.d.ts +122 -0
  543. package/dist/commonjs/regionalAuthority.d.ts.map +1 -0
  544. package/dist/commonjs/regionalAuthority.js +144 -0
  545. package/dist/commonjs/regionalAuthority.js.map +1 -0
  546. package/dist/commonjs/tokenCredentialOptions.d.ts +28 -0
  547. package/dist/commonjs/tokenCredentialOptions.d.ts.map +1 -0
  548. package/dist/commonjs/tokenCredentialOptions.js +5 -0
  549. package/dist/commonjs/tokenCredentialOptions.js.map +1 -0
  550. package/dist/commonjs/tokenProvider.d.ts +39 -0
  551. package/dist/commonjs/tokenProvider.d.ts.map +1 -0
  552. package/dist/commonjs/tokenProvider.js +56 -0
  553. package/dist/commonjs/tokenProvider.js.map +1 -0
  554. package/dist/commonjs/tsdoc-metadata.json +11 -0
  555. package/dist/commonjs/util/identityTokenEndpoint.d.ts +2 -0
  556. package/dist/commonjs/util/identityTokenEndpoint.d.ts.map +1 -0
  557. package/dist/commonjs/util/identityTokenEndpoint.js +14 -0
  558. package/dist/commonjs/util/identityTokenEndpoint.js.map +1 -0
  559. package/dist/commonjs/util/logging.d.ts +70 -0
  560. package/dist/commonjs/util/logging.d.ts.map +1 -0
  561. package/dist/commonjs/util/logging.js +103 -0
  562. package/dist/commonjs/util/logging.js.map +1 -0
  563. package/dist/commonjs/util/processMultiTenantRequest.d.ts +10 -0
  564. package/dist/commonjs/util/processMultiTenantRequest.d.ts.map +1 -0
  565. package/dist/commonjs/util/processMultiTenantRequest.js +38 -0
  566. package/dist/commonjs/util/processMultiTenantRequest.js.map +1 -0
  567. package/dist/commonjs/util/processUtils.d.ts +13 -0
  568. package/dist/commonjs/util/processUtils.d.ts.map +1 -0
  569. package/dist/commonjs/util/processUtils.js +36 -0
  570. package/dist/commonjs/util/processUtils.js.map +1 -0
  571. package/dist/commonjs/util/scopeUtils.d.ts +17 -0
  572. package/dist/commonjs/util/scopeUtils.d.ts.map +1 -0
  573. package/dist/commonjs/util/scopeUtils.js +34 -0
  574. package/dist/commonjs/util/scopeUtils.js.map +1 -0
  575. package/dist/commonjs/util/subscriptionUtils.d.ts +6 -0
  576. package/dist/commonjs/util/subscriptionUtils.d.ts.map +1 -0
  577. package/dist/commonjs/util/subscriptionUtils.js +17 -0
  578. package/dist/commonjs/util/subscriptionUtils.js.map +1 -0
  579. package/dist/commonjs/util/tenantIdUtils.d.ts +15 -0
  580. package/dist/commonjs/util/tenantIdUtils.d.ts.map +1 -0
  581. package/dist/commonjs/util/tenantIdUtils.js +51 -0
  582. package/dist/commonjs/util/tenantIdUtils.js.map +1 -0
  583. package/dist/commonjs/util/tracing.d.ts +6 -0
  584. package/dist/commonjs/util/tracing.d.ts.map +1 -0
  585. package/dist/commonjs/util/tracing.js +17 -0
  586. package/dist/commonjs/util/tracing.js.map +1 -0
  587. package/dist/esm/client/identityClient.d.ts +65 -0
  588. package/dist/esm/client/identityClient.d.ts.map +1 -0
  589. package/dist/esm/client/identityClient.js +248 -0
  590. package/dist/esm/client/identityClient.js.map +1 -0
  591. package/dist/esm/constants.d.ts +69 -0
  592. package/dist/esm/constants.d.ts.map +1 -0
  593. package/dist/esm/constants.js +75 -0
  594. package/dist/esm/constants.js.map +1 -0
  595. package/dist/esm/credentials/authorityValidationOptions.d.ts +16 -0
  596. package/dist/esm/credentials/authorityValidationOptions.d.ts.map +1 -0
  597. package/dist/esm/credentials/authorityValidationOptions.js +4 -0
  598. package/dist/esm/credentials/authorityValidationOptions.js.map +1 -0
  599. package/dist/esm/credentials/authorizationCodeCredential.d.ts +73 -0
  600. package/dist/esm/credentials/authorizationCodeCredential.d.ts.map +1 -0
  601. package/dist/esm/credentials/authorizationCodeCredential.js +60 -0
  602. package/dist/esm/credentials/authorizationCodeCredential.js.map +1 -0
  603. package/dist/esm/credentials/authorizationCodeCredentialOptions.d.ts +8 -0
  604. package/dist/esm/credentials/authorizationCodeCredentialOptions.d.ts.map +1 -0
  605. package/dist/esm/credentials/authorizationCodeCredentialOptions.js +4 -0
  606. package/dist/esm/credentials/authorizationCodeCredentialOptions.js.map +1 -0
  607. package/dist/esm/credentials/azureApplicationCredential.d.ts +24 -0
  608. package/dist/esm/credentials/azureApplicationCredential.d.ts.map +1 -0
  609. package/dist/esm/credentials/azureApplicationCredential.js +32 -0
  610. package/dist/esm/credentials/azureApplicationCredential.js.map +1 -0
  611. package/dist/esm/credentials/azureApplicationCredentialOptions.d.ts +13 -0
  612. package/dist/esm/credentials/azureApplicationCredentialOptions.d.ts.map +1 -0
  613. package/dist/esm/credentials/azureApplicationCredentialOptions.js +4 -0
  614. package/dist/esm/credentials/azureApplicationCredentialOptions.js.map +1 -0
  615. package/dist/esm/credentials/azureCliCredential.d.ts +64 -0
  616. package/dist/esm/credentials/azureCliCredential.d.ts.map +1 -0
  617. package/dist/esm/credentials/azureCliCredential.js +189 -0
  618. package/dist/esm/credentials/azureCliCredential.js.map +1 -0
  619. package/dist/esm/credentials/azureCliCredentialOptions.d.ts +20 -0
  620. package/dist/esm/credentials/azureCliCredentialOptions.d.ts.map +1 -0
  621. package/dist/esm/credentials/azureCliCredentialOptions.js +4 -0
  622. package/dist/esm/credentials/azureCliCredentialOptions.js.map +1 -0
  623. package/dist/esm/credentials/azureDeveloperCliCredential.d.ts +71 -0
  624. package/dist/esm/credentials/azureDeveloperCliCredential.d.ts.map +1 -0
  625. package/dist/esm/credentials/azureDeveloperCliCredential.js +171 -0
  626. package/dist/esm/credentials/azureDeveloperCliCredential.js.map +1 -0
  627. package/dist/esm/credentials/azureDeveloperCliCredentialOptions.d.ts +15 -0
  628. package/dist/esm/credentials/azureDeveloperCliCredentialOptions.d.ts.map +1 -0
  629. package/dist/esm/credentials/azureDeveloperCliCredentialOptions.js +4 -0
  630. package/dist/esm/credentials/azureDeveloperCliCredentialOptions.js.map +1 -0
  631. package/dist/esm/credentials/azurePipelinesCredential.d.ts +38 -0
  632. package/dist/esm/credentials/azurePipelinesCredential.d.ts.map +1 -0
  633. package/dist/esm/credentials/azurePipelinesCredential.js +141 -0
  634. package/dist/esm/credentials/azurePipelinesCredential.js.map +1 -0
  635. package/dist/esm/credentials/azurePipelinesCredentialOptions.d.ts +9 -0
  636. package/dist/esm/credentials/azurePipelinesCredentialOptions.d.ts.map +1 -0
  637. package/dist/esm/credentials/azurePipelinesCredentialOptions.js +4 -0
  638. package/dist/esm/credentials/azurePipelinesCredentialOptions.js.map +1 -0
  639. package/dist/esm/credentials/azurePowerShellCredential.d.ts +75 -0
  640. package/dist/esm/credentials/azurePowerShellCredential.d.ts.map +1 -0
  641. package/dist/esm/credentials/azurePowerShellCredential.js +229 -0
  642. package/dist/esm/credentials/azurePowerShellCredential.js.map +1 -0
  643. package/dist/esm/credentials/azurePowerShellCredentialOptions.d.ts +15 -0
  644. package/dist/esm/credentials/azurePowerShellCredentialOptions.d.ts.map +1 -0
  645. package/dist/esm/credentials/azurePowerShellCredentialOptions.js +4 -0
  646. package/dist/esm/credentials/azurePowerShellCredentialOptions.js.map +1 -0
  647. package/dist/esm/credentials/brokerAuthOptions.d.ts +13 -0
  648. package/dist/esm/credentials/brokerAuthOptions.d.ts.map +1 -0
  649. package/dist/esm/credentials/brokerAuthOptions.js +2 -0
  650. package/dist/esm/credentials/brokerAuthOptions.js.map +1 -0
  651. package/dist/esm/credentials/browserCustomizationOptions.d.ts +19 -0
  652. package/dist/esm/credentials/browserCustomizationOptions.d.ts.map +1 -0
  653. package/dist/esm/credentials/browserCustomizationOptions.js +4 -0
  654. package/dist/esm/credentials/browserCustomizationOptions.js.map +1 -0
  655. package/dist/esm/credentials/chainedTokenCredential.d.ts +51 -0
  656. package/dist/esm/credentials/chainedTokenCredential.d.ts.map +1 -0
  657. package/dist/esm/credentials/chainedTokenCredential.js +92 -0
  658. package/dist/esm/credentials/chainedTokenCredential.js.map +1 -0
  659. package/dist/esm/credentials/clientAssertionCredential.d.ts +33 -0
  660. package/dist/esm/credentials/clientAssertionCredential.d.ts.map +1 -0
  661. package/dist/esm/credentials/clientAssertionCredential.js +55 -0
  662. package/dist/esm/credentials/clientAssertionCredential.js.map +1 -0
  663. package/dist/esm/credentials/clientAssertionCredentialOptions.d.ts +9 -0
  664. package/dist/esm/credentials/clientAssertionCredentialOptions.d.ts.map +1 -0
  665. package/dist/esm/credentials/clientAssertionCredentialOptions.js +4 -0
  666. package/dist/esm/credentials/clientAssertionCredentialOptions.js.map +1 -0
  667. package/dist/esm/credentials/clientCertificateCredential.d.ts +72 -0
  668. package/dist/esm/credentials/clientCertificateCredential.d.ts.map +1 -0
  669. package/dist/esm/credentials/clientCertificateCredential.js +122 -0
  670. package/dist/esm/credentials/clientCertificateCredential.js.map +1 -0
  671. package/dist/esm/credentials/clientCertificateCredentialModels.d.ts +31 -0
  672. package/dist/esm/credentials/clientCertificateCredentialModels.d.ts.map +1 -0
  673. package/dist/esm/credentials/clientCertificateCredentialModels.js +4 -0
  674. package/dist/esm/credentials/clientCertificateCredentialModels.js.map +1 -0
  675. package/dist/esm/credentials/clientCertificateCredentialOptions.d.ts +14 -0
  676. package/dist/esm/credentials/clientCertificateCredentialOptions.d.ts.map +1 -0
  677. package/dist/esm/credentials/clientCertificateCredentialOptions.js +4 -0
  678. package/dist/esm/credentials/clientCertificateCredentialOptions.js.map +1 -0
  679. package/dist/esm/credentials/clientSecretCredential.d.ts +37 -0
  680. package/dist/esm/credentials/clientSecretCredential.d.ts.map +1 -0
  681. package/dist/esm/credentials/clientSecretCredential.js +60 -0
  682. package/dist/esm/credentials/clientSecretCredential.js.map +1 -0
  683. package/dist/esm/credentials/clientSecretCredentialOptions.d.ts +9 -0
  684. package/dist/esm/credentials/clientSecretCredentialOptions.d.ts.map +1 -0
  685. package/dist/esm/credentials/clientSecretCredentialOptions.js +4 -0
  686. package/dist/esm/credentials/clientSecretCredentialOptions.js.map +1 -0
  687. package/dist/esm/credentials/credentialPersistenceOptions.d.ts +30 -0
  688. package/dist/esm/credentials/credentialPersistenceOptions.d.ts.map +1 -0
  689. package/dist/esm/credentials/credentialPersistenceOptions.js +4 -0
  690. package/dist/esm/credentials/credentialPersistenceOptions.js.map +1 -0
  691. package/dist/esm/credentials/defaultAzureCredential.d.ts +65 -0
  692. package/dist/esm/credentials/defaultAzureCredential.d.ts.map +1 -0
  693. package/dist/esm/credentials/defaultAzureCredential.js +164 -0
  694. package/dist/esm/credentials/defaultAzureCredential.js.map +1 -0
  695. package/dist/esm/credentials/defaultAzureCredentialOptions.d.ts +49 -0
  696. package/dist/esm/credentials/defaultAzureCredentialOptions.d.ts.map +1 -0
  697. package/dist/esm/credentials/defaultAzureCredentialOptions.js +4 -0
  698. package/dist/esm/credentials/defaultAzureCredentialOptions.js.map +1 -0
  699. package/dist/esm/credentials/deviceCodeCredential.d.ts +67 -0
  700. package/dist/esm/credentials/deviceCodeCredential.d.ts.map +1 -0
  701. package/dist/esm/credentials/deviceCodeCredential.js +91 -0
  702. package/dist/esm/credentials/deviceCodeCredential.js.map +1 -0
  703. package/dist/esm/credentials/deviceCodeCredentialOptions.d.ts +53 -0
  704. package/dist/esm/credentials/deviceCodeCredentialOptions.d.ts.map +1 -0
  705. package/dist/esm/credentials/deviceCodeCredentialOptions.js +4 -0
  706. package/dist/esm/credentials/deviceCodeCredentialOptions.js.map +1 -0
  707. package/dist/esm/credentials/environmentCredential.d.ts +52 -0
  708. package/dist/esm/credentials/environmentCredential.d.ts.map +1 -0
  709. package/dist/esm/credentials/environmentCredential.js +130 -0
  710. package/dist/esm/credentials/environmentCredential.js.map +1 -0
  711. package/dist/esm/credentials/environmentCredentialOptions.d.ts +9 -0
  712. package/dist/esm/credentials/environmentCredentialOptions.d.ts.map +1 -0
  713. package/dist/esm/credentials/environmentCredentialOptions.js +4 -0
  714. package/dist/esm/credentials/environmentCredentialOptions.js.map +1 -0
  715. package/dist/esm/credentials/interactiveBrowserCredential.d.ts +56 -0
  716. package/dist/esm/credentials/interactiveBrowserCredential.d.ts.map +1 -0
  717. package/dist/esm/credentials/interactiveBrowserCredential.js +91 -0
  718. package/dist/esm/credentials/interactiveBrowserCredential.js.map +1 -0
  719. package/dist/esm/credentials/interactiveBrowserCredentialOptions.d.ts +77 -0
  720. package/dist/esm/credentials/interactiveBrowserCredentialOptions.d.ts.map +1 -0
  721. package/dist/esm/credentials/interactiveBrowserCredentialOptions.js +4 -0
  722. package/dist/esm/credentials/interactiveBrowserCredentialOptions.js.map +1 -0
  723. package/dist/esm/credentials/interactiveCredentialOptions.d.ts +25 -0
  724. package/dist/esm/credentials/interactiveCredentialOptions.d.ts.map +1 -0
  725. package/dist/esm/credentials/interactiveCredentialOptions.js +4 -0
  726. package/dist/esm/credentials/interactiveCredentialOptions.js.map +1 -0
  727. package/dist/esm/credentials/managedIdentityCredential/imdsMsi.d.ts +18 -0
  728. package/dist/esm/credentials/managedIdentityCredential/imdsMsi.d.ts.map +1 -0
  729. package/dist/esm/credentials/managedIdentityCredential/imdsMsi.js +122 -0
  730. package/dist/esm/credentials/managedIdentityCredential/imdsMsi.js.map +1 -0
  731. package/dist/esm/credentials/managedIdentityCredential/imdsRetryPolicy.d.ts +12 -0
  732. package/dist/esm/credentials/managedIdentityCredential/imdsRetryPolicy.d.ts.map +1 -0
  733. package/dist/esm/credentials/managedIdentityCredential/imdsRetryPolicy.js +33 -0
  734. package/dist/esm/credentials/managedIdentityCredential/imdsRetryPolicy.js.map +1 -0
  735. package/dist/esm/credentials/managedIdentityCredential/index.d.ts +61 -0
  736. package/dist/esm/credentials/managedIdentityCredential/index.d.ts.map +1 -0
  737. package/dist/esm/credentials/managedIdentityCredential/index.js +217 -0
  738. package/dist/esm/credentials/managedIdentityCredential/index.js.map +1 -0
  739. package/dist/esm/credentials/managedIdentityCredential/models.d.ts +24 -0
  740. package/dist/esm/credentials/managedIdentityCredential/models.d.ts.map +1 -0
  741. package/dist/esm/credentials/managedIdentityCredential/models.js +4 -0
  742. package/dist/esm/credentials/managedIdentityCredential/models.js.map +1 -0
  743. package/dist/esm/credentials/managedIdentityCredential/options.d.ts +37 -0
  744. package/dist/esm/credentials/managedIdentityCredential/options.d.ts.map +1 -0
  745. package/dist/esm/credentials/managedIdentityCredential/options.js +4 -0
  746. package/dist/esm/credentials/managedIdentityCredential/options.js.map +1 -0
  747. package/dist/esm/credentials/managedIdentityCredential/tokenExchangeMsi.d.ts +14 -0
  748. package/dist/esm/credentials/managedIdentityCredential/tokenExchangeMsi.d.ts.map +1 -0
  749. package/dist/esm/credentials/managedIdentityCredential/tokenExchangeMsi.js +32 -0
  750. package/dist/esm/credentials/managedIdentityCredential/tokenExchangeMsi.js.map +1 -0
  751. package/dist/esm/credentials/managedIdentityCredential/utils.d.ts +33 -0
  752. package/dist/esm/credentials/managedIdentityCredential/utils.d.ts.map +1 -0
  753. package/dist/esm/credentials/managedIdentityCredential/utils.js +77 -0
  754. package/dist/esm/credentials/managedIdentityCredential/utils.js.map +1 -0
  755. package/dist/esm/credentials/multiTenantTokenCredentialOptions.d.ts +12 -0
  756. package/dist/esm/credentials/multiTenantTokenCredentialOptions.d.ts.map +1 -0
  757. package/dist/esm/credentials/multiTenantTokenCredentialOptions.js +4 -0
  758. package/dist/esm/credentials/multiTenantTokenCredentialOptions.js.map +1 -0
  759. package/dist/esm/credentials/onBehalfOfCredential.d.ts +105 -0
  760. package/dist/esm/credentials/onBehalfOfCredential.d.ts.map +1 -0
  761. package/dist/esm/credentials/onBehalfOfCredential.js +112 -0
  762. package/dist/esm/credentials/onBehalfOfCredential.js.map +1 -0
  763. package/dist/esm/credentials/onBehalfOfCredentialOptions.d.ts +76 -0
  764. package/dist/esm/credentials/onBehalfOfCredentialOptions.d.ts.map +1 -0
  765. package/dist/esm/credentials/onBehalfOfCredentialOptions.js +4 -0
  766. package/dist/esm/credentials/onBehalfOfCredentialOptions.js.map +1 -0
  767. package/dist/esm/credentials/usernamePasswordCredential.d.ts +41 -0
  768. package/dist/esm/credentials/usernamePasswordCredential.d.ts.map +1 -0
  769. package/dist/esm/credentials/usernamePasswordCredential.js +67 -0
  770. package/dist/esm/credentials/usernamePasswordCredential.js.map +1 -0
  771. package/dist/esm/credentials/usernamePasswordCredentialOptions.d.ts +9 -0
  772. package/dist/esm/credentials/usernamePasswordCredentialOptions.d.ts.map +1 -0
  773. package/dist/esm/credentials/usernamePasswordCredentialOptions.js +4 -0
  774. package/dist/esm/credentials/usernamePasswordCredentialOptions.js.map +1 -0
  775. package/dist/esm/credentials/visualStudioCodeCredential.d.ts +60 -0
  776. package/dist/esm/credentials/visualStudioCodeCredential.d.ts.map +1 -0
  777. package/dist/esm/credentials/visualStudioCodeCredential.js +190 -0
  778. package/dist/esm/credentials/visualStudioCodeCredential.js.map +1 -0
  779. package/dist/esm/credentials/visualStudioCodeCredentialOptions.d.ts +11 -0
  780. package/dist/esm/credentials/visualStudioCodeCredentialOptions.d.ts.map +1 -0
  781. package/dist/esm/credentials/visualStudioCodeCredentialOptions.js +4 -0
  782. package/dist/esm/credentials/visualStudioCodeCredentialOptions.js.map +1 -0
  783. package/dist/esm/credentials/visualStudioCodeCredentialPlugin.d.ts +11 -0
  784. package/dist/esm/credentials/visualStudioCodeCredentialPlugin.d.ts.map +1 -0
  785. package/dist/esm/credentials/visualStudioCodeCredentialPlugin.js +4 -0
  786. package/dist/esm/credentials/visualStudioCodeCredentialPlugin.js.map +1 -0
  787. package/dist/esm/credentials/workloadIdentityCredential.d.ts +47 -0
  788. package/dist/esm/credentials/workloadIdentityCredential.d.ts.map +1 -0
  789. package/dist/esm/credentials/workloadIdentityCredential.js +114 -0
  790. package/dist/esm/credentials/workloadIdentityCredential.js.map +1 -0
  791. package/dist/esm/credentials/workloadIdentityCredentialOptions.d.ts +20 -0
  792. package/dist/esm/credentials/workloadIdentityCredentialOptions.d.ts.map +1 -0
  793. package/dist/esm/credentials/workloadIdentityCredentialOptions.js +4 -0
  794. package/dist/esm/credentials/workloadIdentityCredentialOptions.js.map +1 -0
  795. package/dist/esm/errors.d.ts +139 -0
  796. package/dist/esm/errors.d.ts.map +1 -0
  797. package/dist/esm/errors.js +123 -0
  798. package/dist/esm/errors.js.map +1 -0
  799. package/dist/esm/index.d.ts +61 -0
  800. package/dist/esm/index.d.ts.map +1 -0
  801. package/dist/esm/index.js +34 -0
  802. package/dist/esm/index.js.map +1 -0
  803. package/dist/esm/msal/browserFlows/flows.d.ts +42 -0
  804. package/dist/esm/msal/browserFlows/flows.d.ts.map +1 -0
  805. package/dist/esm/msal/browserFlows/flows.js +4 -0
  806. package/dist/esm/msal/browserFlows/flows.js.map +1 -0
  807. package/dist/esm/msal/browserFlows/msalAuthCode.d.ts +48 -0
  808. package/dist/esm/msal/browserFlows/msalAuthCode.d.ts.map +1 -0
  809. package/dist/esm/msal/browserFlows/msalAuthCode.js +203 -0
  810. package/dist/esm/msal/browserFlows/msalAuthCode.js.map +1 -0
  811. package/dist/esm/msal/browserFlows/msalBrowserCommon.d.ts +106 -0
  812. package/dist/esm/msal/browserFlows/msalBrowserCommon.d.ts.map +1 -0
  813. package/dist/esm/msal/browserFlows/msalBrowserCommon.js +116 -0
  814. package/dist/esm/msal/browserFlows/msalBrowserCommon.js.map +1 -0
  815. package/dist/esm/msal/credentials.d.ts +52 -0
  816. package/dist/esm/msal/credentials.d.ts.map +1 -0
  817. package/dist/esm/msal/credentials.js +4 -0
  818. package/dist/esm/msal/credentials.js.map +1 -0
  819. package/dist/esm/msal/msal.d.ts +3 -0
  820. package/dist/esm/msal/msal.d.ts.map +1 -0
  821. package/dist/esm/msal/nodeFlows/brokerOptions.d.ts +44 -0
  822. package/dist/esm/msal/nodeFlows/brokerOptions.d.ts.map +1 -0
  823. package/dist/esm/msal/nodeFlows/brokerOptions.js +2 -0
  824. package/dist/esm/msal/nodeFlows/brokerOptions.js.map +1 -0
  825. package/dist/esm/msal/nodeFlows/msalClient.d.ts +186 -0
  826. package/dist/esm/msal/nodeFlows/msalClient.d.ts.map +1 -0
  827. package/dist/esm/msal/nodeFlows/msalClient.js +477 -0
  828. package/dist/esm/msal/nodeFlows/msalClient.js.map +1 -0
  829. package/dist/esm/msal/nodeFlows/msalPlugins.d.ts +91 -0
  830. package/dist/esm/msal/nodeFlows/msalPlugins.d.ts.map +1 -0
  831. package/dist/esm/msal/nodeFlows/msalPlugins.js +87 -0
  832. package/dist/esm/msal/nodeFlows/msalPlugins.js.map +1 -0
  833. package/dist/esm/msal/nodeFlows/tokenCachePersistenceOptions.d.ts +24 -0
  834. package/dist/esm/msal/nodeFlows/tokenCachePersistenceOptions.d.ts.map +1 -0
  835. package/dist/esm/msal/nodeFlows/tokenCachePersistenceOptions.js +4 -0
  836. package/dist/esm/msal/nodeFlows/tokenCachePersistenceOptions.js.map +1 -0
  837. package/dist/esm/msal/types.d.ts +87 -0
  838. package/dist/esm/msal/types.d.ts.map +1 -0
  839. package/dist/esm/msal/types.js +4 -0
  840. package/dist/esm/msal/types.js.map +1 -0
  841. package/dist/esm/msal/utils.d.ts +95 -0
  842. package/dist/esm/msal/utils.d.ts.map +1 -0
  843. package/dist/esm/msal/utils.js +238 -0
  844. package/dist/esm/msal/utils.js.map +1 -0
  845. package/dist/esm/package.json +3 -0
  846. package/dist/esm/plugins/consumer.d.ts +28 -0
  847. package/dist/esm/plugins/consumer.d.ts.map +1 -0
  848. package/dist/esm/plugins/consumer.js +43 -0
  849. package/dist/esm/plugins/consumer.js.map +1 -0
  850. package/dist/esm/plugins/provider.d.ts +36 -0
  851. package/dist/esm/plugins/provider.d.ts.map +1 -0
  852. package/dist/esm/plugins/provider.js +4 -0
  853. package/dist/esm/plugins/provider.js.map +1 -0
  854. package/dist/esm/regionalAuthority.d.ts +122 -0
  855. package/dist/esm/regionalAuthority.d.ts.map +1 -0
  856. package/dist/esm/regionalAuthority.js +140 -0
  857. package/dist/esm/regionalAuthority.js.map +1 -0
  858. package/dist/esm/tokenCredentialOptions.d.ts +28 -0
  859. package/dist/esm/tokenCredentialOptions.d.ts.map +1 -0
  860. package/dist/esm/tokenCredentialOptions.js +4 -0
  861. package/dist/esm/tokenCredentialOptions.js.map +1 -0
  862. package/dist/esm/tokenProvider.d.ts +39 -0
  863. package/dist/esm/tokenProvider.d.ts.map +1 -0
  864. package/dist/esm/tokenProvider.js +53 -0
  865. package/dist/esm/tokenProvider.js.map +1 -0
  866. package/dist/esm/util/authHostEnv-browser.d.mts +4 -0
  867. package/dist/esm/util/authHostEnv-browser.d.mts.map +1 -0
  868. package/dist/esm/util/authHostEnv-browser.mjs +7 -0
  869. package/dist/esm/util/authHostEnv-browser.mjs.map +1 -0
  870. package/dist/esm/util/identityTokenEndpoint.d.ts +2 -0
  871. package/dist/esm/util/identityTokenEndpoint.d.ts.map +1 -0
  872. package/dist/esm/util/identityTokenEndpoint.js +11 -0
  873. package/dist/esm/util/identityTokenEndpoint.js.map +1 -0
  874. package/dist/esm/util/logging.d.ts +70 -0
  875. package/dist/esm/util/logging.d.ts.map +1 -0
  876. package/dist/esm/util/logging.js +94 -0
  877. package/dist/esm/util/logging.js.map +1 -0
  878. package/dist/esm/util/processMultiTenantRequest.d.ts +10 -0
  879. package/dist/esm/util/processMultiTenantRequest.d.ts.map +1 -0
  880. package/dist/esm/util/processMultiTenantRequest.js +35 -0
  881. package/dist/esm/util/processMultiTenantRequest.js.map +1 -0
  882. package/dist/esm/util/processUtils.d.ts +13 -0
  883. package/dist/esm/util/processUtils.d.ts.map +1 -0
  884. package/dist/esm/util/processUtils.js +32 -0
  885. package/dist/esm/util/processUtils.js.map +1 -0
  886. package/dist/esm/util/scopeUtils.d.ts +17 -0
  887. package/dist/esm/util/scopeUtils.d.ts.map +1 -0
  888. package/dist/esm/util/scopeUtils.js +29 -0
  889. package/dist/esm/util/scopeUtils.js.map +1 -0
  890. package/dist/esm/util/subscriptionUtils.d.ts +6 -0
  891. package/dist/esm/util/subscriptionUtils.d.ts.map +1 -0
  892. package/dist/esm/util/subscriptionUtils.js +14 -0
  893. package/dist/esm/util/subscriptionUtils.js.map +1 -0
  894. package/dist/esm/util/tenantIdUtils.d.ts +15 -0
  895. package/dist/esm/util/tenantIdUtils.d.ts.map +1 -0
  896. package/dist/esm/util/tenantIdUtils.js +44 -0
  897. package/dist/esm/util/tenantIdUtils.js.map +1 -0
  898. package/dist/esm/util/tracing.d.ts +6 -0
  899. package/dist/esm/util/tracing.d.ts.map +1 -0
  900. package/dist/esm/util/tracing.js +14 -0
  901. package/dist/esm/util/tracing.js.map +1 -0
  902. package/package.json +65 -79
  903. package/dist/index.js +0 -4211
  904. package/dist/index.js.map +0 -1
  905. package/dist-esm/src/client/identityClient.js +0 -248
  906. package/dist-esm/src/client/identityClient.js.map +0 -1
  907. package/dist-esm/src/constants.js +0 -67
  908. package/dist-esm/src/constants.js.map +0 -1
  909. package/dist-esm/src/credentials/authorizationCodeCredential.browser.js +0 -16
  910. package/dist-esm/src/credentials/authorizationCodeCredential.browser.js.map +0 -1
  911. package/dist-esm/src/credentials/authorizationCodeCredential.js +0 -60
  912. package/dist-esm/src/credentials/authorizationCodeCredential.js.map +0 -1
  913. package/dist-esm/src/credentials/authorizationCodeCredentialOptions.js.map +0 -1
  914. package/dist-esm/src/credentials/azureApplicationCredential.browser.js +0 -34
  915. package/dist-esm/src/credentials/azureApplicationCredential.browser.js.map +0 -1
  916. package/dist-esm/src/credentials/azureApplicationCredential.js +0 -32
  917. package/dist-esm/src/credentials/azureApplicationCredential.js.map +0 -1
  918. package/dist-esm/src/credentials/azureApplicationCredentialOptions.js.map +0 -1
  919. package/dist-esm/src/credentials/azureCliCredential.browser.js +0 -23
  920. package/dist-esm/src/credentials/azureCliCredential.browser.js.map +0 -1
  921. package/dist-esm/src/credentials/azureCliCredential.js +0 -175
  922. package/dist-esm/src/credentials/azureCliCredential.js.map +0 -1
  923. package/dist-esm/src/credentials/azureCliCredentialOptions.js.map +0 -1
  924. package/dist-esm/src/credentials/azureDeveloperCliCredential.browser.js +0 -23
  925. package/dist-esm/src/credentials/azureDeveloperCliCredential.browser.js.map +0 -1
  926. package/dist-esm/src/credentials/azureDeveloperCliCredential.js +0 -171
  927. package/dist-esm/src/credentials/azureDeveloperCliCredential.js.map +0 -1
  928. package/dist-esm/src/credentials/azureDeveloperCliCredentialOptions.js.map +0 -1
  929. package/dist-esm/src/credentials/azurePipelinesCredential.browser.js +0 -23
  930. package/dist-esm/src/credentials/azurePipelinesCredential.browser.js.map +0 -1
  931. package/dist-esm/src/credentials/azurePipelinesCredential.js +0 -141
  932. package/dist-esm/src/credentials/azurePipelinesCredential.js.map +0 -1
  933. package/dist-esm/src/credentials/azurePipelinesCredentialOptions.js.map +0 -1
  934. package/dist-esm/src/credentials/azurePowerShellCredential.browser.js +0 -22
  935. package/dist-esm/src/credentials/azurePowerShellCredential.browser.js.map +0 -1
  936. package/dist-esm/src/credentials/azurePowerShellCredential.js +0 -229
  937. package/dist-esm/src/credentials/azurePowerShellCredential.js.map +0 -1
  938. package/dist-esm/src/credentials/azurePowerShellCredentialOptions.js.map +0 -1
  939. package/dist-esm/src/credentials/brokerAuthOptions.js.map +0 -1
  940. package/dist-esm/src/credentials/chainedTokenCredential.js +0 -89
  941. package/dist-esm/src/credentials/chainedTokenCredential.js.map +0 -1
  942. package/dist-esm/src/credentials/clientAssertionCredential.browser.js +0 -22
  943. package/dist-esm/src/credentials/clientAssertionCredential.browser.js.map +0 -1
  944. package/dist-esm/src/credentials/clientAssertionCredential.js +0 -55
  945. package/dist-esm/src/credentials/clientAssertionCredential.js.map +0 -1
  946. package/dist-esm/src/credentials/clientAssertionCredentialOptions.js.map +0 -1
  947. package/dist-esm/src/credentials/clientCertificateCredential.browser.js +0 -23
  948. package/dist-esm/src/credentials/clientCertificateCredential.browser.js.map +0 -1
  949. package/dist-esm/src/credentials/clientCertificateCredential.js +0 -119
  950. package/dist-esm/src/credentials/clientCertificateCredential.js.map +0 -1
  951. package/dist-esm/src/credentials/clientCertificateCredentialOptions.js.map +0 -1
  952. package/dist-esm/src/credentials/clientSecretCredential.browser.js +0 -83
  953. package/dist-esm/src/credentials/clientSecretCredential.browser.js.map +0 -1
  954. package/dist-esm/src/credentials/clientSecretCredential.js +0 -60
  955. package/dist-esm/src/credentials/clientSecretCredential.js.map +0 -1
  956. package/dist-esm/src/credentials/clientSecretCredentialOptions.js.map +0 -1
  957. package/dist-esm/src/credentials/credentialPersistenceOptions.js.map +0 -1
  958. package/dist-esm/src/credentials/defaultAzureCredential.browser.js +0 -29
  959. package/dist-esm/src/credentials/defaultAzureCredential.browser.js.map +0 -1
  960. package/dist-esm/src/credentials/defaultAzureCredential.js +0 -151
  961. package/dist-esm/src/credentials/defaultAzureCredential.js.map +0 -1
  962. package/dist-esm/src/credentials/defaultAzureCredentialOptions.js.map +0 -1
  963. package/dist-esm/src/credentials/deviceCodeCredential.browser.js +0 -23
  964. package/dist-esm/src/credentials/deviceCodeCredential.browser.js.map +0 -1
  965. package/dist-esm/src/credentials/deviceCodeCredential.js +0 -91
  966. package/dist-esm/src/credentials/deviceCodeCredential.js.map +0 -1
  967. package/dist-esm/src/credentials/deviceCodeCredentialOptions.js.map +0 -1
  968. package/dist-esm/src/credentials/environmentCredential.browser.js +0 -23
  969. package/dist-esm/src/credentials/environmentCredential.browser.js.map +0 -1
  970. package/dist-esm/src/credentials/environmentCredential.js +0 -130
  971. package/dist-esm/src/credentials/environmentCredential.js.map +0 -1
  972. package/dist-esm/src/credentials/environmentCredentialOptions.js.map +0 -1
  973. package/dist-esm/src/credentials/interactiveBrowserCredential.browser.js +0 -86
  974. package/dist-esm/src/credentials/interactiveBrowserCredential.browser.js.map +0 -1
  975. package/dist-esm/src/credentials/interactiveBrowserCredential.js +0 -91
  976. package/dist-esm/src/credentials/interactiveBrowserCredential.js.map +0 -1
  977. package/dist-esm/src/credentials/interactiveBrowserCredentialOptions.js.map +0 -1
  978. package/dist-esm/src/credentials/interactiveCredentialOptions.js.map +0 -1
  979. package/dist-esm/src/credentials/managedIdentityCredential/appServiceMsi2017.js +0 -71
  980. package/dist-esm/src/credentials/managedIdentityCredential/appServiceMsi2017.js.map +0 -1
  981. package/dist-esm/src/credentials/managedIdentityCredential/appServiceMsi2019.js +0 -71
  982. package/dist-esm/src/credentials/managedIdentityCredential/appServiceMsi2019.js.map +0 -1
  983. package/dist-esm/src/credentials/managedIdentityCredential/arcMsi.js +0 -140
  984. package/dist-esm/src/credentials/managedIdentityCredential/arcMsi.js.map +0 -1
  985. package/dist-esm/src/credentials/managedIdentityCredential/cloudShellMsi.js +0 -75
  986. package/dist-esm/src/credentials/managedIdentityCredential/cloudShellMsi.js.map +0 -1
  987. package/dist-esm/src/credentials/managedIdentityCredential/constants.js +0 -9
  988. package/dist-esm/src/credentials/managedIdentityCredential/constants.js.map +0 -1
  989. package/dist-esm/src/credentials/managedIdentityCredential/fabricMsi.js +0 -95
  990. package/dist-esm/src/credentials/managedIdentityCredential/fabricMsi.js.map +0 -1
  991. package/dist-esm/src/credentials/managedIdentityCredential/imdsMsi.js +0 -144
  992. package/dist-esm/src/credentials/managedIdentityCredential/imdsMsi.js.map +0 -1
  993. package/dist-esm/src/credentials/managedIdentityCredential/imdsRetryPolicy.js.map +0 -1
  994. package/dist-esm/src/credentials/managedIdentityCredential/index.browser.js +0 -16
  995. package/dist-esm/src/credentials/managedIdentityCredential/index.browser.js.map +0 -1
  996. package/dist-esm/src/credentials/managedIdentityCredential/index.js +0 -37
  997. package/dist-esm/src/credentials/managedIdentityCredential/index.js.map +0 -1
  998. package/dist-esm/src/credentials/managedIdentityCredential/legacyMsiProvider.js +0 -309
  999. package/dist-esm/src/credentials/managedIdentityCredential/legacyMsiProvider.js.map +0 -1
  1000. package/dist-esm/src/credentials/managedIdentityCredential/models.js.map +0 -1
  1001. package/dist-esm/src/credentials/managedIdentityCredential/msalMsiProvider.js +0 -212
  1002. package/dist-esm/src/credentials/managedIdentityCredential/msalMsiProvider.js.map +0 -1
  1003. package/dist-esm/src/credentials/managedIdentityCredential/tokenExchangeMsi.js +0 -29
  1004. package/dist-esm/src/credentials/managedIdentityCredential/tokenExchangeMsi.js.map +0 -1
  1005. package/dist-esm/src/credentials/managedIdentityCredential/utils.js +0 -77
  1006. package/dist-esm/src/credentials/managedIdentityCredential/utils.js.map +0 -1
  1007. package/dist-esm/src/credentials/multiTenantTokenCredentialOptions.js.map +0 -1
  1008. package/dist-esm/src/credentials/onBehalfOfCredential.browser.js +0 -23
  1009. package/dist-esm/src/credentials/onBehalfOfCredential.browser.js.map +0 -1
  1010. package/dist-esm/src/credentials/onBehalfOfCredential.js +0 -112
  1011. package/dist-esm/src/credentials/onBehalfOfCredential.js.map +0 -1
  1012. package/dist-esm/src/credentials/onBehalfOfCredentialOptions.js.map +0 -1
  1013. package/dist-esm/src/credentials/usernamePasswordCredential.browser.js +0 -77
  1014. package/dist-esm/src/credentials/usernamePasswordCredential.browser.js.map +0 -1
  1015. package/dist-esm/src/credentials/usernamePasswordCredential.js +0 -67
  1016. package/dist-esm/src/credentials/usernamePasswordCredential.js.map +0 -1
  1017. package/dist-esm/src/credentials/usernamePasswordCredentialOptions.js.map +0 -1
  1018. package/dist-esm/src/credentials/visualStudioCodeCredential.browser.js +0 -27
  1019. package/dist-esm/src/credentials/visualStudioCodeCredential.browser.js.map +0 -1
  1020. package/dist-esm/src/credentials/visualStudioCodeCredential.js +0 -190
  1021. package/dist-esm/src/credentials/visualStudioCodeCredential.js.map +0 -1
  1022. package/dist-esm/src/credentials/visualStudioCodeCredentialOptions.js.map +0 -1
  1023. package/dist-esm/src/credentials/workloadIdentityCredential.browser.js +0 -27
  1024. package/dist-esm/src/credentials/workloadIdentityCredential.browser.js.map +0 -1
  1025. package/dist-esm/src/credentials/workloadIdentityCredential.js +0 -114
  1026. package/dist-esm/src/credentials/workloadIdentityCredential.js.map +0 -1
  1027. package/dist-esm/src/credentials/workloadIdentityCredentialOptions.js.map +0 -1
  1028. package/dist-esm/src/errors.js.map +0 -1
  1029. package/dist-esm/src/index.js +0 -34
  1030. package/dist-esm/src/index.js.map +0 -1
  1031. package/dist-esm/src/msal/browserFlows/flows.js.map +0 -1
  1032. package/dist-esm/src/msal/browserFlows/msalAuthCode.js +0 -203
  1033. package/dist-esm/src/msal/browserFlows/msalAuthCode.js.map +0 -1
  1034. package/dist-esm/src/msal/browserFlows/msalBrowserCommon.js +0 -116
  1035. package/dist-esm/src/msal/browserFlows/msalBrowserCommon.js.map +0 -1
  1036. package/dist-esm/src/msal/credentials.js.map +0 -1
  1037. package/dist-esm/src/msal/msal.browser.js +0 -5
  1038. package/dist-esm/src/msal/msal.browser.js.map +0 -1
  1039. package/dist-esm/src/msal/nodeFlows/msalClient.js +0 -484
  1040. package/dist-esm/src/msal/nodeFlows/msalClient.js.map +0 -1
  1041. package/dist-esm/src/msal/nodeFlows/msalPlugins.js +0 -87
  1042. package/dist-esm/src/msal/nodeFlows/msalPlugins.js.map +0 -1
  1043. package/dist-esm/src/msal/types.js.map +0 -1
  1044. package/dist-esm/src/msal/utils.js +0 -232
  1045. package/dist-esm/src/msal/utils.js.map +0 -1
  1046. package/dist-esm/src/plugins/consumer.browser.js +0 -7
  1047. package/dist-esm/src/plugins/consumer.browser.js.map +0 -1
  1048. package/dist-esm/src/plugins/consumer.js +0 -43
  1049. package/dist-esm/src/plugins/consumer.js.map +0 -1
  1050. package/dist-esm/src/plugins/provider.js.map +0 -1
  1051. package/dist-esm/src/tokenCredentialOptions.js.map +0 -1
  1052. package/dist-esm/src/tokenProvider.js +0 -52
  1053. package/dist-esm/src/tokenProvider.js.map +0 -1
  1054. package/dist-esm/src/util/authHostEnv.browser.js +0 -7
  1055. package/dist-esm/src/util/authHostEnv.browser.js.map +0 -1
  1056. package/dist-esm/src/util/logging.js.map +0 -1
  1057. package/dist-esm/src/util/processMultiTenantRequest.browser.js +0 -29
  1058. package/dist-esm/src/util/processMultiTenantRequest.browser.js.map +0 -1
  1059. package/dist-esm/src/util/processMultiTenantRequest.js +0 -35
  1060. package/dist-esm/src/util/processMultiTenantRequest.js.map +0 -1
  1061. package/dist-esm/src/util/scopeUtils.js +0 -29
  1062. package/dist-esm/src/util/scopeUtils.js.map +0 -1
  1063. package/dist-esm/src/util/tenantIdUtils.js +0 -44
  1064. package/dist-esm/src/util/tenantIdUtils.js.map +0 -1
  1065. package/dist-esm/src/util/tracing.js +0 -14
  1066. package/dist-esm/src/util/tracing.js.map +0 -1
  1067. package/types/identity.d.ts +0 -1853
  1068. /package/{dist-esm/src → dist/browser}/credentials/authorityValidationOptions.js +0 -0
  1069. /package/{dist-esm/src → dist/browser}/credentials/authorityValidationOptions.js.map +0 -0
  1070. /package/{dist-esm/src → dist/browser}/credentials/authorizationCodeCredentialOptions.js +0 -0
  1071. /package/{dist-esm/src → dist/browser}/credentials/azureApplicationCredentialOptions.js +0 -0
  1072. /package/{dist-esm/src → dist/browser}/credentials/azureCliCredentialOptions.js +0 -0
  1073. /package/{dist-esm/src → dist/browser}/credentials/azureDeveloperCliCredentialOptions.js +0 -0
  1074. /package/{dist-esm/src → dist/browser}/credentials/azurePipelinesCredentialOptions.js +0 -0
  1075. /package/{dist-esm/src → dist/browser}/credentials/azurePowerShellCredentialOptions.js +0 -0
  1076. /package/{dist-esm/src → dist/browser}/credentials/brokerAuthOptions.js +0 -0
  1077. /package/{dist-esm/src → dist/browser}/credentials/browserCustomizationOptions.js +0 -0
  1078. /package/{dist-esm/src → dist/browser}/credentials/browserCustomizationOptions.js.map +0 -0
  1079. /package/{dist-esm/src → dist/browser}/credentials/clientAssertionCredentialOptions.js +0 -0
  1080. /package/{dist-esm/src → dist/browser}/credentials/clientCertificateCredentialOptions.js +0 -0
  1081. /package/{dist-esm/src → dist/browser}/credentials/clientSecretCredentialOptions.js +0 -0
  1082. /package/{dist-esm/src → dist/browser}/credentials/credentialPersistenceOptions.js +0 -0
  1083. /package/{dist-esm/src → dist/browser}/credentials/defaultAzureCredentialOptions.js +0 -0
  1084. /package/{dist-esm/src → dist/browser}/credentials/deviceCodeCredentialOptions.js +0 -0
  1085. /package/{dist-esm/src → dist/browser}/credentials/environmentCredentialOptions.js +0 -0
  1086. /package/{dist-esm/src → dist/browser}/credentials/interactiveBrowserCredentialOptions.js +0 -0
  1087. /package/{dist-esm/src → dist/browser}/credentials/interactiveCredentialOptions.js +0 -0
  1088. /package/{dist-esm/src → dist/browser}/credentials/managedIdentityCredential/imdsRetryPolicy.js +0 -0
  1089. /package/{dist-esm/src → dist/browser}/credentials/managedIdentityCredential/models.js +0 -0
  1090. /package/{dist-esm/src → dist/browser}/credentials/multiTenantTokenCredentialOptions.js +0 -0
  1091. /package/{dist-esm/src → dist/browser}/credentials/onBehalfOfCredentialOptions.js +0 -0
  1092. /package/{dist-esm/src → dist/browser}/credentials/usernamePasswordCredentialOptions.js +0 -0
  1093. /package/{dist-esm/src → dist/browser}/credentials/visualStudioCodeCredentialOptions.js +0 -0
  1094. /package/{dist-esm/src → dist/browser}/credentials/visualStudioCodeCredentialPlugin.js +0 -0
  1095. /package/{dist-esm/src → dist/browser}/credentials/visualStudioCodeCredentialPlugin.js.map +0 -0
  1096. /package/{dist-esm/src → dist/browser}/credentials/workloadIdentityCredentialOptions.js +0 -0
  1097. /package/{dist-esm/src → dist/browser}/errors.js +0 -0
  1098. /package/{dist-esm/src → dist/browser}/msal/browserFlows/flows.js +0 -0
  1099. /package/{dist-esm/src → dist/browser}/msal/credentials.js +0 -0
  1100. /package/{dist-esm/src → dist/browser}/msal/nodeFlows/brokerOptions.js +0 -0
  1101. /package/{dist-esm/src → dist/browser}/msal/nodeFlows/brokerOptions.js.map +0 -0
  1102. /package/{dist-esm/src → dist/browser}/msal/nodeFlows/tokenCachePersistenceOptions.js +0 -0
  1103. /package/{dist-esm/src → dist/browser}/msal/nodeFlows/tokenCachePersistenceOptions.js.map +0 -0
  1104. /package/{dist-esm/src → dist/browser}/msal/types.js +0 -0
  1105. /package/{dist-esm/src → dist/browser}/plugins/provider.js +0 -0
  1106. /package/{dist-esm/src → dist/browser}/regionalAuthority.js +0 -0
  1107. /package/{dist-esm/src → dist/browser}/regionalAuthority.js.map +0 -0
  1108. /package/{dist-esm/src → dist/browser}/tokenCredentialOptions.js +0 -0
  1109. /package/{dist-esm/src → dist/browser}/util/identityTokenEndpoint.js +0 -0
  1110. /package/{dist-esm/src → dist/browser}/util/identityTokenEndpoint.js.map +0 -0
  1111. /package/{dist-esm/src → dist/browser}/util/logging.js +0 -0
  1112. /package/{dist-esm/src → dist/browser}/util/processUtils.js +0 -0
  1113. /package/{dist-esm/src → dist/browser}/util/processUtils.js.map +0 -0
  1114. /package/{dist-esm/src → dist/esm}/msal/msal.js +0 -0
  1115. /package/{dist-esm/src → dist/esm}/msal/msal.js.map +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"file":"legacyMsiProvider.js","sourceRoot":"","sources":["../../../../src/credentials/managedIdentityCredential/legacyMsiProvider.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { AccessToken, GetTokenOptions } from \"@azure/core-auth\";\nimport { AppTokenProviderParameters, ConfidentialClientApplication } from \"@azure/msal-node\";\nimport {\n AuthenticationError,\n AuthenticationRequiredError,\n CredentialUnavailableError,\n} from \"../../errors\";\nimport { MSI, MSIConfiguration, MSIToken } from \"./models\";\nimport { MsalResult, MsalToken, ValidMsalToken } from \"../../msal/types\";\nimport { cloudShellMsi } from \"./cloudShellMsi\";\nimport { credentialLogger, formatError, formatSuccess } from \"../../util/logging\";\n\nimport { DeveloperSignOnClientId } from \"../../constants\";\nimport { IdentityClient } from \"../../client/identityClient\";\nimport { TokenCredentialOptions } from \"../../tokenCredentialOptions\";\nimport { appServiceMsi2017 } from \"./appServiceMsi2017\";\nimport { appServiceMsi2019 } from \"./appServiceMsi2019\";\nimport { arcMsi } from \"./arcMsi\";\nimport { fabricMsi } from \"./fabricMsi\";\nimport { getLogLevel } from \"@azure/logger\";\nimport { getMSALLogLevel } from \"../../msal/utils\";\nimport { imdsMsi } from \"./imdsMsi\";\nimport { tokenExchangeMsi } from \"./tokenExchangeMsi\";\nimport { tracingClient } from \"../../util/tracing\";\n\nconst logger = credentialLogger(\"ManagedIdentityCredential\");\n\n// As part of the migration of Managed Identity to MSAL, this legacy provider captures the existing behavior\n// ported over from the ManagedIdentityCredential verbatim. This is to ensure that the existing behavior\n// is maintained while the new implementation is being tested and validated.\n// https://github.com/Azure/azure-sdk-for-js/issues/30189 tracks deleting this provider once it is no longer needed.\n\n/**\n * Options to send on the {@link ManagedIdentityCredential} constructor.\n * Since this is an internal implementation, uses a looser interface than the public one.\n */\ninterface ManagedIdentityCredentialOptions extends TokenCredentialOptions {\n /**\n * The client ID of the user - assigned identity, or app registration(when working with AKS pod - identity).\n */\n clientId?: string;\n\n /**\n * Allows specifying a custom resource Id.\n * In scenarios such as when user assigned identities are created using an ARM template,\n * where the resource Id of the identity is known but the client Id can't be known ahead of time,\n * this parameter allows programs to use these user assigned identities\n * without having to first determine the client Id of the created identity.\n */\n resourceId?: string;\n}\n\nexport class LegacyMsiProvider {\n private identityClient: IdentityClient;\n private clientId: string | undefined;\n private resourceId: string | undefined;\n private isEndpointUnavailable: boolean | null = null;\n private isAvailableIdentityClient: IdentityClient;\n private confidentialApp: ConfidentialClientApplication;\n private isAppTokenProviderInitialized: boolean = false;\n private msiRetryConfig: MSIConfiguration[\"retryConfig\"] = {\n maxRetries: 5,\n startDelayInMs: 800,\n intervalIncrement: 2,\n };\n\n constructor(\n clientIdOrOptions?: string | ManagedIdentityCredentialOptions,\n options?: TokenCredentialOptions,\n ) {\n let _options: TokenCredentialOptions | undefined;\n if (typeof clientIdOrOptions === \"string\") {\n this.clientId = clientIdOrOptions;\n _options = options;\n } else {\n this.clientId = (clientIdOrOptions as ManagedIdentityCredentialOptions)?.clientId;\n _options = clientIdOrOptions;\n }\n this.resourceId = (_options as ManagedIdentityCredentialOptions)?.resourceId;\n // For JavaScript users.\n if (this.clientId && this.resourceId) {\n throw new Error(\n `ManagedIdentityCredential - Client Id and Resource Id can't be provided at the same time.`,\n );\n }\n if (_options?.retryOptions?.maxRetries !== undefined) {\n this.msiRetryConfig.maxRetries = _options.retryOptions.maxRetries;\n }\n this.identityClient = new IdentityClient(_options);\n this.isAvailableIdentityClient = new IdentityClient({\n ..._options,\n retryOptions: {\n maxRetries: 0,\n },\n });\n\n /** authority host validation and metadata discovery to be skipped in managed identity\n * since this wasn't done previously before adding token cache support\n */\n this.confidentialApp = new ConfidentialClientApplication({\n auth: {\n authority: \"https://login.microsoftonline.com/managed_identity\",\n clientId: this.clientId ?? DeveloperSignOnClientId,\n clientSecret: \"dummy-secret\",\n cloudDiscoveryMetadata:\n '{\"tenant_discovery_endpoint\":\"https://login.microsoftonline.com/common/v2.0/.well-known/openid-configuration\",\"api-version\":\"1.1\",\"metadata\":[{\"preferred_network\":\"login.microsoftonline.com\",\"preferred_cache\":\"login.windows.net\",\"aliases\":[\"login.microsoftonline.com\",\"login.windows.net\",\"login.microsoft.com\",\"sts.windows.net\"]},{\"preferred_network\":\"login.partner.microsoftonline.cn\",\"preferred_cache\":\"login.partner.microsoftonline.cn\",\"aliases\":[\"login.partner.microsoftonline.cn\",\"login.chinacloudapi.cn\"]},{\"preferred_network\":\"login.microsoftonline.de\",\"preferred_cache\":\"login.microsoftonline.de\",\"aliases\":[\"login.microsoftonline.de\"]},{\"preferred_network\":\"login.microsoftonline.us\",\"preferred_cache\":\"login.microsoftonline.us\",\"aliases\":[\"login.microsoftonline.us\",\"login.usgovcloudapi.net\"]},{\"preferred_network\":\"login-us.microsoftonline.com\",\"preferred_cache\":\"login-us.microsoftonline.com\",\"aliases\":[\"login-us.microsoftonline.com\"]}]}',\n authorityMetadata:\n '{\"token_endpoint\":\"https://login.microsoftonline.com/common/oauth2/v2.0/token\",\"token_endpoint_auth_methods_supported\":[\"client_secret_post\",\"private_key_jwt\",\"client_secret_basic\"],\"jwks_uri\":\"https://login.microsoftonline.com/common/discovery/v2.0/keys\",\"response_modes_supported\":[\"query\",\"fragment\",\"form_post\"],\"subject_types_supported\":[\"pairwise\"],\"id_token_signing_alg_values_supported\":[\"RS256\"],\"response_types_supported\":[\"code\",\"id_token\",\"code id_token\",\"id_token token\"],\"scopes_supported\":[\"openid\",\"profile\",\"email\",\"offline_access\"],\"issuer\":\"https://login.microsoftonline.com/{tenantid}/v2.0\",\"request_uri_parameter_supported\":false,\"userinfo_endpoint\":\"https://graph.microsoft.com/oidc/userinfo\",\"authorization_endpoint\":\"https://login.microsoftonline.com/common/oauth2/v2.0/authorize\",\"device_authorization_endpoint\":\"https://login.microsoftonline.com/common/oauth2/v2.0/devicecode\",\"http_logout_supported\":true,\"frontchannel_logout_supported\":true,\"end_session_endpoint\":\"https://login.microsoftonline.com/common/oauth2/v2.0/logout\",\"claims_supported\":[\"sub\",\"iss\",\"cloud_instance_name\",\"cloud_instance_host_name\",\"cloud_graph_host_name\",\"msgraph_host\",\"aud\",\"exp\",\"iat\",\"auth_time\",\"acr\",\"nonce\",\"preferred_username\",\"name\",\"tid\",\"ver\",\"at_hash\",\"c_hash\",\"email\"],\"kerberos_endpoint\":\"https://login.microsoftonline.com/common/kerberos\",\"tenant_region_scope\":null,\"cloud_instance_name\":\"microsoftonline.com\",\"cloud_graph_host_name\":\"graph.windows.net\",\"msgraph_host\":\"graph.microsoft.com\",\"rbac_url\":\"https://pas.windows.net\"}',\n clientCapabilities: [],\n },\n system: {\n loggerOptions: {\n logLevel: getMSALLogLevel(getLogLevel()),\n },\n },\n });\n }\n\n private cachedMSI: MSI | undefined;\n\n private async cachedAvailableMSI(\n scopes: string | string[],\n getTokenOptions?: GetTokenOptions,\n ): Promise<MSI> {\n if (this.cachedMSI) {\n return this.cachedMSI;\n }\n\n const MSIs = [\n arcMsi,\n fabricMsi,\n appServiceMsi2019,\n appServiceMsi2017,\n cloudShellMsi,\n tokenExchangeMsi,\n imdsMsi,\n ];\n\n for (const msi of MSIs) {\n if (\n await msi.isAvailable({\n scopes,\n identityClient: this.isAvailableIdentityClient,\n clientId: this.clientId,\n resourceId: this.resourceId,\n getTokenOptions,\n })\n ) {\n this.cachedMSI = msi;\n return msi;\n }\n }\n\n throw new CredentialUnavailableError(`ManagedIdentityCredential - No MSI credential available`);\n }\n\n private async authenticateManagedIdentity(\n scopes: string | string[],\n getTokenOptions?: GetTokenOptions,\n ): Promise<MSIToken | null> {\n const { span, updatedOptions } = tracingClient.startSpan(\n `ManagedIdentityCredential.authenticateManagedIdentity`,\n getTokenOptions,\n );\n\n try {\n // Determining the available MSI, and avoiding checking for other MSIs while the program is running.\n const availableMSI = await this.cachedAvailableMSI(scopes, updatedOptions);\n return availableMSI.getToken(\n {\n identityClient: this.identityClient,\n scopes,\n clientId: this.clientId,\n resourceId: this.resourceId,\n retryConfig: this.msiRetryConfig,\n },\n updatedOptions,\n );\n } catch (err: any) {\n span.setStatus({\n status: \"error\",\n error: err,\n });\n throw err;\n } finally {\n span.end();\n }\n }\n\n /**\n * Authenticates with Microsoft Entra ID and returns an access token if successful.\n * If authentication fails, a {@link CredentialUnavailableError} will be thrown with the details of the failure.\n * If an unexpected error occurs, an {@link AuthenticationError} will be thrown with the details of the failure.\n *\n * @param scopes - The list of scopes for which the token will have access.\n * @param options - The options used to configure any requests this\n * TokenCredential implementation might make.\n */\n public async getToken(\n scopes: string | string[],\n options?: GetTokenOptions,\n ): Promise<AccessToken> {\n let result: AccessToken | null = null;\n const { span, updatedOptions } = tracingClient.startSpan(\n `ManagedIdentityCredential.getToken`,\n options,\n );\n try {\n // isEndpointAvailable can be true, false, or null,\n // If it's null, it means we don't yet know whether\n // the endpoint is available and need to check for it.\n if (this.isEndpointUnavailable !== true) {\n const availableMSI = await this.cachedAvailableMSI(scopes, updatedOptions);\n if (availableMSI.name === \"tokenExchangeMsi\") {\n result = await this.authenticateManagedIdentity(scopes, updatedOptions);\n } else {\n const appTokenParameters: AppTokenProviderParameters = {\n correlationId: this.identityClient.getCorrelationId(),\n tenantId: options?.tenantId || \"managed_identity\",\n scopes: Array.isArray(scopes) ? scopes : [scopes],\n claims: options?.claims,\n };\n\n // Added a check to see if SetAppTokenProvider was already defined.\n this.initializeSetAppTokenProvider();\n const authenticationResult = await this.confidentialApp.acquireTokenByClientCredential({\n ...appTokenParameters,\n });\n result = this.handleResult(scopes, authenticationResult || undefined);\n }\n if (result === null) {\n // If authenticateManagedIdentity returns null,\n // it means no MSI endpoints are available.\n // If so, we avoid trying to reach to them in future requests.\n this.isEndpointUnavailable = true;\n\n // It also means that the endpoint answered with either 200 or 201 (see the sendTokenRequest method),\n // yet we had no access token. For this reason, we'll throw once with a specific message:\n const error = new CredentialUnavailableError(\n \"The managed identity endpoint was reached, yet no tokens were received.\",\n );\n logger.getToken.info(formatError(scopes, error));\n throw error;\n }\n\n // Since `authenticateManagedIdentity` didn't throw, and the result was not null,\n // We will assume that this endpoint is reachable from this point forward,\n // and avoid pinging again to it.\n this.isEndpointUnavailable = false;\n } else {\n // We've previously determined that the endpoint was unavailable,\n // either because it was unreachable or permanently unable to authenticate.\n const error = new CredentialUnavailableError(\n \"The managed identity endpoint is not currently available\",\n );\n logger.getToken.info(formatError(scopes, error));\n throw error;\n }\n\n logger.getToken.info(formatSuccess(scopes));\n return result;\n } catch (err: any) {\n // CredentialUnavailable errors are expected to reach here.\n // We intend them to bubble up, so that DefaultAzureCredential can catch them.\n if (err.name === \"AuthenticationRequiredError\") {\n throw err;\n }\n\n // Expected errors to reach this point:\n // - Errors coming from a method unexpectedly breaking.\n // - When identityClient.sendTokenRequest throws, in which case\n // if the status code was 400, it means that the endpoint is working,\n // but no identity is available.\n\n span.setStatus({\n status: \"error\",\n error: err,\n });\n\n // If either the network is unreachable,\n // we can safely assume the credential is unavailable.\n if (err.code === \"ENETUNREACH\") {\n const error = new CredentialUnavailableError(\n `ManagedIdentityCredential: Unavailable. Network unreachable. Message: ${err.message}`,\n );\n\n logger.getToken.info(formatError(scopes, error));\n throw error;\n }\n\n // If either the host was unreachable,\n // we can safely assume the credential is unavailable.\n if (err.code === \"EHOSTUNREACH\") {\n const error = new CredentialUnavailableError(\n `ManagedIdentityCredential: Unavailable. No managed identity endpoint found. Message: ${err.message}`,\n );\n\n logger.getToken.info(formatError(scopes, error));\n throw error;\n }\n // If err.statusCode has a value of 400, it comes from sendTokenRequest,\n // and it means that the endpoint is working, but that no identity is available.\n if (err.statusCode === 400) {\n throw new CredentialUnavailableError(\n `ManagedIdentityCredential: The managed identity endpoint is indicating there's no available identity. Message: ${err.message}`,\n );\n }\n\n // This is a special case for Docker Desktop which responds with a 403 with a message that contains \"A socket operation was attempted to an unreachable network\" or \"A socket operation was attempted to an unreachable host\"\n // rather than just timing out, as expected.\n if (err.statusCode === 403 || err.code === 403) {\n if (err.message.includes(\"unreachable\")) {\n const error = new CredentialUnavailableError(\n `ManagedIdentityCredential: Unavailable. Network unreachable. Message: ${err.message}`,\n );\n\n logger.getToken.info(formatError(scopes, error));\n throw error;\n }\n }\n\n // If the error has no status code, we can assume there was no available identity.\n // This will throw silently during any ChainedTokenCredential.\n if (err.statusCode === undefined) {\n throw new CredentialUnavailableError(\n `ManagedIdentityCredential: Authentication failed. Message ${err.message}`,\n );\n }\n\n // Any other error should break the chain.\n throw new AuthenticationError(err.statusCode, {\n error: `ManagedIdentityCredential authentication failed.`,\n error_description: err.message,\n });\n } finally {\n // Finally is always called, both if we return and if we throw in the above try/catch.\n span.end();\n }\n }\n\n /**\n * Handles the MSAL authentication result.\n * If the result has an account, we update the local account reference.\n * If the token received is invalid, an error will be thrown depending on what's missing.\n */\n private handleResult(\n scopes: string | string[],\n result?: MsalResult,\n getTokenOptions?: GetTokenOptions,\n ): AccessToken {\n this.ensureValidMsalToken(scopes, result, getTokenOptions);\n logger.getToken.info(formatSuccess(scopes));\n return {\n token: result.accessToken,\n expiresOnTimestamp: result.expiresOn.getTime(),\n refreshAfterTimestamp: result.refreshOn?.getTime(),\n tokenType: \"Bearer\",\n } as AccessToken;\n }\n\n /**\n * Ensures the validity of the MSAL token\n */\n private ensureValidMsalToken(\n scopes: string | string[],\n msalToken?: MsalToken,\n getTokenOptions?: GetTokenOptions,\n ): asserts msalToken is ValidMsalToken {\n const error = (message: string): Error => {\n logger.getToken.info(message);\n return new AuthenticationRequiredError({\n scopes: Array.isArray(scopes) ? scopes : [scopes],\n getTokenOptions,\n message,\n });\n };\n if (!msalToken) {\n throw error(\"No response\");\n }\n if (!msalToken.expiresOn) {\n throw error(`Response had no \"expiresOn\" property.`);\n }\n if (!msalToken.accessToken) {\n throw error(`Response had no \"accessToken\" property.`);\n }\n }\n\n private initializeSetAppTokenProvider(): void {\n if (!this.isAppTokenProviderInitialized) {\n this.confidentialApp.SetAppTokenProvider(async (appTokenProviderParameters) => {\n logger.info(\n `SetAppTokenProvider invoked with parameters- ${JSON.stringify(\n appTokenProviderParameters,\n )}`,\n );\n const getTokenOptions: GetTokenOptions = {\n ...appTokenProviderParameters,\n };\n logger.info(\n `authenticateManagedIdentity invoked with scopes- ${JSON.stringify(\n appTokenProviderParameters.scopes,\n )} and getTokenOptions - ${JSON.stringify(getTokenOptions)}`,\n );\n const resultToken = await this.authenticateManagedIdentity(\n appTokenProviderParameters.scopes,\n getTokenOptions,\n );\n\n if (resultToken) {\n logger.info(`SetAppTokenProvider will save the token in cache`);\n\n const expiresInSeconds = resultToken?.expiresOnTimestamp\n ? Math.floor((resultToken.expiresOnTimestamp - Date.now()) / 1000)\n : 0;\n const refreshInSeconds = resultToken?.refreshAfterTimestamp\n ? Math.floor((resultToken.refreshAfterTimestamp - Date.now()) / 1000)\n : 0;\n return {\n accessToken: resultToken?.token,\n expiresInSeconds,\n refreshInSeconds,\n };\n } else {\n logger.info(\n `SetAppTokenProvider token has \"no_access_token_returned\" as the saved token`,\n );\n return {\n accessToken: \"no_access_token_returned\",\n expiresInSeconds: 0,\n };\n }\n });\n this.isAppTokenProviderInitialized = true;\n }\n }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"models.js","sourceRoot":"","sources":["../../../../src/credentials/managedIdentityCredential/models.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { AccessToken, GetTokenOptions } from \"@azure/core-auth\";\n\nimport { IdentityClient } from \"../../client/identityClient\";\n\n/**\n * @internal\n */\nexport interface MSIConfiguration {\n retryConfig: {\n maxRetries: number;\n startDelayInMs: number;\n intervalIncrement: number;\n };\n identityClient: IdentityClient;\n scopes: string | string[];\n clientId?: string;\n resourceId?: string;\n}\n\n/**\n * @internal\n * Represents an access token for {@link ManagedIdentity} for internal usage,\n * with an expiration time and the time in which token should refresh.\n */\nexport declare interface MSIToken extends AccessToken {}\n\n/**\n * @internal\n */\nexport interface MSI {\n name: string;\n isAvailable(options: {\n scopes: string | string[];\n identityClient?: IdentityClient;\n clientId?: string;\n resourceId?: string;\n getTokenOptions?: GetTokenOptions;\n }): Promise<boolean>;\n getToken(\n configuration: MSIConfiguration,\n getTokenOptions?: GetTokenOptions,\n ): Promise<MSIToken | null>;\n}\n"]}
@@ -1,212 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import { AuthenticationRequiredError, CredentialUnavailableError } from "../../errors";
4
- import { credentialLogger, formatError, formatSuccess } from "../../util/logging";
5
- import { defaultLoggerCallback, getMSALLogLevel } from "../../msal/utils";
6
- import { IdentityClient } from "../../client/identityClient";
7
- import { ManagedIdentityApplication } from "@azure/msal-node";
8
- import { getLogLevel } from "@azure/logger";
9
- import { imdsMsi } from "./imdsMsi";
10
- import { imdsRetryPolicy } from "./imdsRetryPolicy";
11
- import { mapScopesToResource } from "./utils";
12
- import { tokenExchangeMsi } from "./tokenExchangeMsi";
13
- import { tracingClient } from "../../util/tracing";
14
- const logger = credentialLogger("ManagedIdentityCredential(MSAL)");
15
- export class MsalMsiProvider {
16
- constructor(clientIdOrOptions, options = {}) {
17
- var _a, _b;
18
- this.msiRetryConfig = {
19
- maxRetries: 5,
20
- startDelayInMs: 800,
21
- intervalIncrement: 2,
22
- };
23
- let _options = {};
24
- if (typeof clientIdOrOptions === "string") {
25
- this.clientId = clientIdOrOptions;
26
- _options = options;
27
- }
28
- else {
29
- this.clientId = clientIdOrOptions === null || clientIdOrOptions === void 0 ? void 0 : clientIdOrOptions.clientId;
30
- _options = clientIdOrOptions !== null && clientIdOrOptions !== void 0 ? clientIdOrOptions : {};
31
- }
32
- this.resourceId = _options === null || _options === void 0 ? void 0 : _options.resourceId;
33
- this.objectId = _options === null || _options === void 0 ? void 0 : _options.objectId;
34
- // For JavaScript users.
35
- const providedIds = [this.clientId, this.resourceId, this.objectId].filter(Boolean);
36
- if (providedIds.length > 1) {
37
- throw new Error(`ManagedIdentityCredential: only one of 'clientId', 'resourceId', or 'objectId' can be provided. Received values: ${JSON.stringify({ clientId: this.clientId, resourceId: this.resourceId, objectId: this.objectId })}`);
38
- }
39
- // ManagedIdentity uses http for local requests
40
- _options.allowInsecureConnection = true;
41
- if (((_a = _options === null || _options === void 0 ? void 0 : _options.retryOptions) === null || _a === void 0 ? void 0 : _a.maxRetries) !== undefined) {
42
- this.msiRetryConfig.maxRetries = _options.retryOptions.maxRetries;
43
- }
44
- this.identityClient = new IdentityClient(Object.assign(Object.assign({}, _options), { additionalPolicies: [{ policy: imdsRetryPolicy(this.msiRetryConfig), position: "perCall" }] }));
45
- this.managedIdentityApp = new ManagedIdentityApplication({
46
- managedIdentityIdParams: {
47
- userAssignedClientId: this.clientId,
48
- userAssignedResourceId: this.resourceId,
49
- userAssignedObjectId: this.objectId,
50
- },
51
- system: {
52
- // todo: proxyUrl?
53
- disableInternalRetries: true,
54
- networkClient: this.identityClient,
55
- loggerOptions: {
56
- logLevel: getMSALLogLevel(getLogLevel()),
57
- piiLoggingEnabled: (_b = options.loggingOptions) === null || _b === void 0 ? void 0 : _b.enableUnsafeSupportLogging,
58
- loggerCallback: defaultLoggerCallback(logger),
59
- },
60
- },
61
- });
62
- this.isAvailableIdentityClient = new IdentityClient(Object.assign(Object.assign({}, _options), { retryOptions: {
63
- maxRetries: 0,
64
- } }));
65
- // CloudShell MSI will ignore any user-assigned identity passed as parameters. To avoid confusion, we prevent this from happening as early as possible.
66
- if (this.managedIdentityApp.getManagedIdentitySource() === "CloudShell") {
67
- if (this.clientId || this.resourceId || this.objectId) {
68
- logger.warning(`CloudShell MSI detected with user-provided IDs - throwing. Received values: ${JSON.stringify({
69
- clientId: this.clientId,
70
- resourceId: this.resourceId,
71
- objectId: this.objectId,
72
- })}.`);
73
- throw new CredentialUnavailableError("ManagedIdentityCredential: Specifying a user-assigned managed identity is not supported for CloudShell at runtime. When using Managed Identity in CloudShell, omit the clientId, resourceId, and objectId parameters.");
74
- }
75
- }
76
- }
77
- /**
78
- * Authenticates with Microsoft Entra ID and returns an access token if successful.
79
- * If authentication fails, a {@link CredentialUnavailableError} will be thrown with the details of the failure.
80
- * If an unexpected error occurs, an {@link AuthenticationError} will be thrown with the details of the failure.
81
- *
82
- * @param scopes - The list of scopes for which the token will have access.
83
- * @param options - The options used to configure any requests this
84
- * TokenCredential implementation might make.
85
- */
86
- async getToken(scopes, options = {}) {
87
- logger.getToken.info("Using the MSAL provider for Managed Identity.");
88
- const resource = mapScopesToResource(scopes);
89
- if (!resource) {
90
- throw new CredentialUnavailableError(`ManagedIdentityCredential: Multiple scopes are not supported. Scopes: ${JSON.stringify(scopes)}`);
91
- }
92
- return tracingClient.withSpan("ManagedIdentityCredential.getToken", options, async () => {
93
- var _a;
94
- try {
95
- const isTokenExchangeMsi = await tokenExchangeMsi.isAvailable({
96
- scopes,
97
- clientId: this.clientId,
98
- getTokenOptions: options,
99
- identityClient: this.identityClient,
100
- resourceId: this.resourceId,
101
- });
102
- // Most scenarios are handled by MSAL except for two:
103
- // AKS pod identity - MSAL does not implement the token exchange flow.
104
- // IMDS Endpoint probing - MSAL does not do any probing before trying to get a token.
105
- // As a DefaultAzureCredential optimization we probe the IMDS endpoint with a short timeout and no retries before actually trying to get a token
106
- // We will continue to implement these features in the Identity library.
107
- const identitySource = this.managedIdentityApp.getManagedIdentitySource();
108
- const isImdsMsi = identitySource === "DefaultToImds" || identitySource === "Imds"; // Neither actually checks that IMDS endpoint is available, just that it's the source the MSAL _would_ try to use.
109
- logger.getToken.info(`MSAL Identity source: ${identitySource}`);
110
- if (isTokenExchangeMsi) {
111
- // In the AKS scenario we will use the existing tokenExchangeMsi indefinitely.
112
- logger.getToken.info("Using the token exchange managed identity.");
113
- const result = await tokenExchangeMsi.getToken({
114
- scopes,
115
- clientId: this.clientId,
116
- identityClient: this.identityClient,
117
- retryConfig: this.msiRetryConfig,
118
- resourceId: this.resourceId,
119
- });
120
- if (result === null) {
121
- throw new CredentialUnavailableError("Attempted to use the token exchange managed identity, but received a null response.");
122
- }
123
- return result;
124
- }
125
- else if (isImdsMsi) {
126
- // In the IMDS scenario we will probe the IMDS endpoint to ensure it's available before trying to get a token.
127
- // If the IMDS endpoint is not available and this is the source that MSAL will use, we will fail-fast with an error that tells DAC to move to the next credential.
128
- logger.getToken.info("Using the IMDS endpoint to probe for availability.");
129
- const isAvailable = await imdsMsi.isAvailable({
130
- scopes,
131
- clientId: this.clientId,
132
- getTokenOptions: options,
133
- identityClient: this.isAvailableIdentityClient,
134
- resourceId: this.resourceId,
135
- });
136
- if (!isAvailable) {
137
- throw new CredentialUnavailableError(`Attempted to use the IMDS endpoint, but it is not available.`);
138
- }
139
- }
140
- // If we got this far, it means:
141
- // - This is not a tokenExchangeMsi,
142
- // - We already probed for IMDS endpoint availability and failed-fast if it's unreachable.
143
- // We can proceed normally by calling MSAL for a token.
144
- logger.getToken.info("Calling into MSAL for managed identity token.");
145
- const token = await this.managedIdentityApp.acquireToken({
146
- resource,
147
- });
148
- this.ensureValidMsalToken(scopes, token, options);
149
- logger.getToken.info(formatSuccess(scopes));
150
- return {
151
- expiresOnTimestamp: token.expiresOn.getTime(),
152
- token: token.accessToken,
153
- refreshAfterTimestamp: (_a = token.refreshOn) === null || _a === void 0 ? void 0 : _a.getTime(),
154
- tokenType: "Bearer",
155
- };
156
- }
157
- catch (err) {
158
- logger.getToken.error(formatError(scopes, err));
159
- // AuthenticationRequiredError described as Error to enforce authentication after trying to retrieve a token silently.
160
- // TODO: why would this _ever_ happen considering we're not trying the silent request in this flow?
161
- if (err.name === "AuthenticationRequiredError") {
162
- throw err;
163
- }
164
- if (isNetworkError(err)) {
165
- throw new CredentialUnavailableError(`ManagedIdentityCredential: Network unreachable. Message: ${err.message}`, { cause: err });
166
- }
167
- throw new CredentialUnavailableError(`ManagedIdentityCredential: Authentication failed. Message ${err.message}`, { cause: err });
168
- }
169
- });
170
- }
171
- /**
172
- * Ensures the validity of the MSAL token
173
- */
174
- ensureValidMsalToken(scopes, msalToken, getTokenOptions) {
175
- const createError = (message) => {
176
- logger.getToken.info(message);
177
- return new AuthenticationRequiredError({
178
- scopes: Array.isArray(scopes) ? scopes : [scopes],
179
- getTokenOptions,
180
- message,
181
- });
182
- };
183
- if (!msalToken) {
184
- throw createError("No response.");
185
- }
186
- if (!msalToken.expiresOn) {
187
- throw createError(`Response had no "expiresOn" property.`);
188
- }
189
- if (!msalToken.accessToken) {
190
- throw createError(`Response had no "accessToken" property.`);
191
- }
192
- }
193
- }
194
- function isNetworkError(err) {
195
- // MSAL error
196
- if (err.errorCode === "network_error") {
197
- return true;
198
- }
199
- // Probe errors
200
- if (err.code === "ENETUNREACH" || err.code === "EHOSTUNREACH") {
201
- return true;
202
- }
203
- // This is a special case for Docker Desktop which responds with a 403 with a message that contains "A socket operation was attempted to an unreachable network" or "A socket operation was attempted to an unreachable host"
204
- // rather than just timing out, as expected.
205
- if (err.statusCode === 403 || err.code === 403) {
206
- if (err.message.includes("unreachable")) {
207
- return true;
208
- }
209
- }
210
- return false;
211
- }
212
- //# sourceMappingURL=msalMsiProvider.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"msalMsiProvider.js","sourceRoot":"","sources":["../../../../src/credentials/managedIdentityCredential/msalMsiProvider.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { AccessToken, GetTokenOptions } from \"@azure/core-auth\";\nimport { AuthenticationRequiredError, CredentialUnavailableError } from \"../../errors\";\nimport { MsalToken, ValidMsalToken } from \"../../msal/types\";\nimport { credentialLogger, formatError, formatSuccess } from \"../../util/logging\";\nimport { defaultLoggerCallback, getMSALLogLevel } from \"../../msal/utils\";\n\nimport { IdentityClient } from \"../../client/identityClient\";\nimport { MSIConfiguration } from \"./models\";\nimport { ManagedIdentityApplication } from \"@azure/msal-node\";\nimport { TokenCredentialOptions } from \"../../tokenCredentialOptions\";\nimport { getLogLevel } from \"@azure/logger\";\nimport { imdsMsi } from \"./imdsMsi\";\nimport { imdsRetryPolicy } from \"./imdsRetryPolicy\";\nimport { mapScopesToResource } from \"./utils\";\nimport { tokenExchangeMsi } from \"./tokenExchangeMsi\";\nimport { tracingClient } from \"../../util/tracing\";\n\nconst logger = credentialLogger(\"ManagedIdentityCredential(MSAL)\");\n\n/**\n * Options to send on the {@link ManagedIdentityCredential} constructor.\n * Since this is an internal implementation, uses a looser interface than the public one.\n */\ninterface ManagedIdentityCredentialOptions extends TokenCredentialOptions {\n /**\n * The client ID of the user - assigned identity, or app registration(when working with AKS pod - identity).\n */\n clientId?: string;\n\n /**\n * Allows specifying a custom resource Id.\n * In scenarios such as when user assigned identities are created using an ARM template,\n * where the resource Id of the identity is known but the client Id can't be known ahead of time,\n * this parameter allows programs to use these user assigned identities\n * without having to first determine the client Id of the created identity.\n */\n resourceId?: string;\n\n /**\n * Allows specifying the object ID of the underlying service principal used to authenticate a user-assigned managed identity.\n * This is an alternative to providing a client ID and is not required for system-assigned managed identities.\n */\n objectId?: string;\n}\n\nexport class MsalMsiProvider {\n private managedIdentityApp: ManagedIdentityApplication;\n private identityClient: IdentityClient;\n private clientId?: string;\n private resourceId?: string;\n private objectId?: string;\n private msiRetryConfig: MSIConfiguration[\"retryConfig\"] = {\n maxRetries: 5,\n startDelayInMs: 800,\n intervalIncrement: 2,\n };\n private isAvailableIdentityClient: IdentityClient;\n\n constructor(\n clientIdOrOptions?: string | ManagedIdentityCredentialOptions,\n options: ManagedIdentityCredentialOptions = {},\n ) {\n let _options: ManagedIdentityCredentialOptions = {};\n if (typeof clientIdOrOptions === \"string\") {\n this.clientId = clientIdOrOptions;\n _options = options;\n } else {\n this.clientId = clientIdOrOptions?.clientId;\n _options = clientIdOrOptions ?? {};\n }\n this.resourceId = _options?.resourceId;\n this.objectId = _options?.objectId;\n\n // For JavaScript users.\n const providedIds = [this.clientId, this.resourceId, this.objectId].filter(Boolean);\n if (providedIds.length > 1) {\n throw new Error(\n `ManagedIdentityCredential: only one of 'clientId', 'resourceId', or 'objectId' can be provided. Received values: ${JSON.stringify(\n { clientId: this.clientId, resourceId: this.resourceId, objectId: this.objectId },\n )}`,\n );\n }\n\n // ManagedIdentity uses http for local requests\n _options.allowInsecureConnection = true;\n\n if (_options?.retryOptions?.maxRetries !== undefined) {\n this.msiRetryConfig.maxRetries = _options.retryOptions.maxRetries;\n }\n\n this.identityClient = new IdentityClient({\n ..._options,\n additionalPolicies: [{ policy: imdsRetryPolicy(this.msiRetryConfig), position: \"perCall\" }],\n });\n\n this.managedIdentityApp = new ManagedIdentityApplication({\n managedIdentityIdParams: {\n userAssignedClientId: this.clientId,\n userAssignedResourceId: this.resourceId,\n userAssignedObjectId: this.objectId,\n },\n system: {\n // todo: proxyUrl?\n disableInternalRetries: true,\n networkClient: this.identityClient,\n loggerOptions: {\n logLevel: getMSALLogLevel(getLogLevel()),\n piiLoggingEnabled: options.loggingOptions?.enableUnsafeSupportLogging,\n loggerCallback: defaultLoggerCallback(logger),\n },\n },\n });\n\n this.isAvailableIdentityClient = new IdentityClient({\n ..._options,\n retryOptions: {\n maxRetries: 0,\n },\n });\n\n // CloudShell MSI will ignore any user-assigned identity passed as parameters. To avoid confusion, we prevent this from happening as early as possible.\n if (this.managedIdentityApp.getManagedIdentitySource() === \"CloudShell\") {\n if (this.clientId || this.resourceId || this.objectId) {\n logger.warning(\n `CloudShell MSI detected with user-provided IDs - throwing. Received values: ${JSON.stringify(\n {\n clientId: this.clientId,\n resourceId: this.resourceId,\n objectId: this.objectId,\n },\n )}.`,\n );\n throw new CredentialUnavailableError(\n \"ManagedIdentityCredential: Specifying a user-assigned managed identity is not supported for CloudShell at runtime. When using Managed Identity in CloudShell, omit the clientId, resourceId, and objectId parameters.\",\n );\n }\n }\n }\n\n /**\n * Authenticates with Microsoft Entra ID and returns an access token if successful.\n * If authentication fails, a {@link CredentialUnavailableError} will be thrown with the details of the failure.\n * If an unexpected error occurs, an {@link AuthenticationError} will be thrown with the details of the failure.\n *\n * @param scopes - The list of scopes for which the token will have access.\n * @param options - The options used to configure any requests this\n * TokenCredential implementation might make.\n */\n public async getToken(\n scopes: string | string[],\n options: GetTokenOptions = {},\n ): Promise<AccessToken> {\n logger.getToken.info(\"Using the MSAL provider for Managed Identity.\");\n const resource = mapScopesToResource(scopes);\n if (!resource) {\n throw new CredentialUnavailableError(\n `ManagedIdentityCredential: Multiple scopes are not supported. Scopes: ${JSON.stringify(\n scopes,\n )}`,\n );\n }\n\n return tracingClient.withSpan(\"ManagedIdentityCredential.getToken\", options, async () => {\n try {\n const isTokenExchangeMsi = await tokenExchangeMsi.isAvailable({\n scopes,\n clientId: this.clientId,\n getTokenOptions: options,\n identityClient: this.identityClient,\n resourceId: this.resourceId,\n });\n\n // Most scenarios are handled by MSAL except for two:\n // AKS pod identity - MSAL does not implement the token exchange flow.\n // IMDS Endpoint probing - MSAL does not do any probing before trying to get a token.\n // As a DefaultAzureCredential optimization we probe the IMDS endpoint with a short timeout and no retries before actually trying to get a token\n // We will continue to implement these features in the Identity library.\n\n const identitySource = this.managedIdentityApp.getManagedIdentitySource();\n const isImdsMsi = identitySource === \"DefaultToImds\" || identitySource === \"Imds\"; // Neither actually checks that IMDS endpoint is available, just that it's the source the MSAL _would_ try to use.\n\n logger.getToken.info(`MSAL Identity source: ${identitySource}`);\n\n if (isTokenExchangeMsi) {\n // In the AKS scenario we will use the existing tokenExchangeMsi indefinitely.\n logger.getToken.info(\"Using the token exchange managed identity.\");\n const result = await tokenExchangeMsi.getToken({\n scopes,\n clientId: this.clientId,\n identityClient: this.identityClient,\n retryConfig: this.msiRetryConfig,\n resourceId: this.resourceId,\n });\n\n if (result === null) {\n throw new CredentialUnavailableError(\n \"Attempted to use the token exchange managed identity, but received a null response.\",\n );\n }\n\n return result;\n } else if (isImdsMsi) {\n // In the IMDS scenario we will probe the IMDS endpoint to ensure it's available before trying to get a token.\n // If the IMDS endpoint is not available and this is the source that MSAL will use, we will fail-fast with an error that tells DAC to move to the next credential.\n logger.getToken.info(\"Using the IMDS endpoint to probe for availability.\");\n const isAvailable = await imdsMsi.isAvailable({\n scopes,\n clientId: this.clientId,\n getTokenOptions: options,\n identityClient: this.isAvailableIdentityClient,\n resourceId: this.resourceId,\n });\n\n if (!isAvailable) {\n throw new CredentialUnavailableError(\n `Attempted to use the IMDS endpoint, but it is not available.`,\n );\n }\n }\n\n // If we got this far, it means:\n // - This is not a tokenExchangeMsi,\n // - We already probed for IMDS endpoint availability and failed-fast if it's unreachable.\n // We can proceed normally by calling MSAL for a token.\n logger.getToken.info(\"Calling into MSAL for managed identity token.\");\n const token = await this.managedIdentityApp.acquireToken({\n resource,\n });\n\n this.ensureValidMsalToken(scopes, token, options);\n logger.getToken.info(formatSuccess(scopes));\n\n return {\n expiresOnTimestamp: token.expiresOn.getTime(),\n token: token.accessToken,\n refreshAfterTimestamp: token.refreshOn?.getTime(),\n tokenType: \"Bearer\",\n } as AccessToken;\n } catch (err: any) {\n logger.getToken.error(formatError(scopes, err));\n\n // AuthenticationRequiredError described as Error to enforce authentication after trying to retrieve a token silently.\n // TODO: why would this _ever_ happen considering we're not trying the silent request in this flow?\n if (err.name === \"AuthenticationRequiredError\") {\n throw err;\n }\n\n if (isNetworkError(err)) {\n throw new CredentialUnavailableError(\n `ManagedIdentityCredential: Network unreachable. Message: ${err.message}`,\n { cause: err },\n );\n }\n\n throw new CredentialUnavailableError(\n `ManagedIdentityCredential: Authentication failed. Message ${err.message}`,\n { cause: err },\n );\n }\n });\n }\n\n /**\n * Ensures the validity of the MSAL token\n */\n private ensureValidMsalToken(\n scopes: string | string[],\n msalToken?: MsalToken,\n getTokenOptions?: GetTokenOptions,\n ): asserts msalToken is ValidMsalToken {\n const createError = (message: string): Error => {\n logger.getToken.info(message);\n return new AuthenticationRequiredError({\n scopes: Array.isArray(scopes) ? scopes : [scopes],\n getTokenOptions,\n message,\n });\n };\n if (!msalToken) {\n throw createError(\"No response.\");\n }\n if (!msalToken.expiresOn) {\n throw createError(`Response had no \"expiresOn\" property.`);\n }\n if (!msalToken.accessToken) {\n throw createError(`Response had no \"accessToken\" property.`);\n }\n }\n}\n\nfunction isNetworkError(err: any): boolean {\n // MSAL error\n if (err.errorCode === \"network_error\") {\n return true;\n }\n\n // Probe errors\n if (err.code === \"ENETUNREACH\" || err.code === \"EHOSTUNREACH\") {\n return true;\n }\n\n // This is a special case for Docker Desktop which responds with a 403 with a message that contains \"A socket operation was attempted to an unreachable network\" or \"A socket operation was attempted to an unreachable host\"\n // rather than just timing out, as expected.\n if (err.statusCode === 403 || err.code === 403) {\n if (err.message.includes(\"unreachable\")) {\n return true;\n }\n }\n\n return false;\n}\n"]}
@@ -1,29 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import { WorkloadIdentityCredential } from "../workloadIdentityCredential";
4
- import { credentialLogger } from "../../util/logging";
5
- const msiName = "ManagedIdentityCredential - Token Exchange";
6
- const logger = credentialLogger(msiName);
7
- /**
8
- * Defines how to determine whether the token exchange MSI is available, and also how to retrieve a token from the token exchange MSI.
9
- */
10
- export const tokenExchangeMsi = {
11
- name: "tokenExchangeMsi",
12
- async isAvailable({ clientId }) {
13
- const env = process.env;
14
- const result = Boolean((clientId || env.AZURE_CLIENT_ID) &&
15
- env.AZURE_TENANT_ID &&
16
- process.env.AZURE_FEDERATED_TOKEN_FILE);
17
- if (!result) {
18
- logger.info(`${msiName}: Unavailable. The environment variables needed are: AZURE_CLIENT_ID (or the client ID sent through the parameters), AZURE_TENANT_ID and AZURE_FEDERATED_TOKEN_FILE`);
19
- }
20
- return result;
21
- },
22
- async getToken(configuration, getTokenOptions = {}) {
23
- const { scopes, clientId } = configuration;
24
- const identityClientTokenCredentialOptions = {};
25
- const workloadIdentityCredential = new WorkloadIdentityCredential(Object.assign(Object.assign({ clientId, tenantId: process.env.AZURE_TENANT_ID, tokenFilePath: process.env.AZURE_FEDERATED_TOKEN_FILE }, identityClientTokenCredentialOptions), { disableInstanceDiscovery: true }));
26
- return workloadIdentityCredential.getToken(scopes, getTokenOptions);
27
- },
28
- };
29
- //# sourceMappingURL=tokenExchangeMsi.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tokenExchangeMsi.js","sourceRoot":"","sources":["../../../../src/credentials/managedIdentityCredential/tokenExchangeMsi.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAIlC,OAAO,EAAE,0BAA0B,EAAE,MAAM,+BAA+B,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,MAAM,OAAO,GAAG,4CAA4C,CAAC;AAC7D,MAAM,MAAM,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;AAEzC;;GAEG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAQ;IACnC,IAAI,EAAE,kBAAkB;IACxB,KAAK,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE;QAC5B,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;QACxB,MAAM,MAAM,GAAG,OAAO,CACpB,CAAC,QAAQ,IAAI,GAAG,CAAC,eAAe,CAAC;YAC/B,GAAG,CAAC,eAAe;YACnB,OAAO,CAAC,GAAG,CAAC,0BAA0B,CACzC,CAAC;QACF,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,CAAC,IAAI,CACT,GAAG,OAAO,qKAAqK,CAChL,CAAC;QACJ,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,KAAK,CAAC,QAAQ,CACZ,aAA+B,EAC/B,kBAAmC,EAAE;QAErC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC;QAC3C,MAAM,oCAAoC,GAAG,EAAE,CAAC;QAChD,MAAM,0BAA0B,GAAG,IAAI,0BAA0B,CAAC,8BAChE,QAAQ,EACR,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,eAAe,EACrC,aAAa,EAAE,OAAO,CAAC,GAAG,CAAC,0BAA0B,IAClD,oCAAoC,KACvC,wBAAwB,EAAE,IAAI,GACM,CAAC,CAAC;QACxC,OAAO,0BAA0B,CAAC,QAAQ,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IACtE,CAAC;CACF,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { AccessToken, GetTokenOptions } from \"@azure/core-auth\";\nimport { MSI, MSIConfiguration } from \"./models\";\nimport { WorkloadIdentityCredential } from \"../workloadIdentityCredential\";\nimport { credentialLogger } from \"../../util/logging\";\nimport { WorkloadIdentityCredentialOptions } from \"../workloadIdentityCredentialOptions\";\n\nconst msiName = \"ManagedIdentityCredential - Token Exchange\";\nconst logger = credentialLogger(msiName);\n\n/**\n * Defines how to determine whether the token exchange MSI is available, and also how to retrieve a token from the token exchange MSI.\n */\nexport const tokenExchangeMsi: MSI = {\n name: \"tokenExchangeMsi\",\n async isAvailable({ clientId }): Promise<boolean> {\n const env = process.env;\n const result = Boolean(\n (clientId || env.AZURE_CLIENT_ID) &&\n env.AZURE_TENANT_ID &&\n process.env.AZURE_FEDERATED_TOKEN_FILE,\n );\n if (!result) {\n logger.info(\n `${msiName}: Unavailable. The environment variables needed are: AZURE_CLIENT_ID (or the client ID sent through the parameters), AZURE_TENANT_ID and AZURE_FEDERATED_TOKEN_FILE`,\n );\n }\n return result;\n },\n async getToken(\n configuration: MSIConfiguration,\n getTokenOptions: GetTokenOptions = {},\n ): Promise<AccessToken | null> {\n const { scopes, clientId } = configuration;\n const identityClientTokenCredentialOptions = {};\n const workloadIdentityCredential = new WorkloadIdentityCredential({\n clientId,\n tenantId: process.env.AZURE_TENANT_ID,\n tokenFilePath: process.env.AZURE_FEDERATED_TOKEN_FILE,\n ...identityClientTokenCredentialOptions,\n disableInstanceDiscovery: true,\n } as WorkloadIdentityCredentialOptions);\n return workloadIdentityCredential.getToken(scopes, getTokenOptions);\n },\n};\n"]}
@@ -1,77 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import { DefaultScopeSuffix } from "./constants";
4
- /**
5
- * Most MSIs send requests to the IMDS endpoint, or a similar endpoint.
6
- * These are GET requests that require sending a `resource` parameter on the query.
7
- * This resource can be derived from the scopes received through the getToken call, as long as only one scope is received.
8
- * Multiple scopes assume that the resulting token will have access to multiple resources, which won't be the case.
9
- *
10
- * For that reason, when we encounter multiple scopes, we return undefined.
11
- * It's up to the individual MSI implementations to throw the errors (which helps us provide less generic errors).
12
- */
13
- export function mapScopesToResource(scopes) {
14
- let scope = "";
15
- if (Array.isArray(scopes)) {
16
- if (scopes.length !== 1) {
17
- return;
18
- }
19
- scope = scopes[0];
20
- }
21
- else if (typeof scopes === "string") {
22
- scope = scopes;
23
- }
24
- if (!scope.endsWith(DefaultScopeSuffix)) {
25
- return scope;
26
- }
27
- return scope.substr(0, scope.lastIndexOf(DefaultScopeSuffix));
28
- }
29
- /**
30
- * Given a token response, return the expiration timestamp as the number of milliseconds from the Unix epoch.
31
- * @param body - A parsed response body from the authentication endpoint.
32
- */
33
- export function parseExpirationTimestamp(body) {
34
- if (typeof body.expires_on === "number") {
35
- return body.expires_on * 1000;
36
- }
37
- if (typeof body.expires_on === "string") {
38
- const asNumber = +body.expires_on;
39
- if (!isNaN(asNumber)) {
40
- return asNumber * 1000;
41
- }
42
- const asDate = Date.parse(body.expires_on);
43
- if (!isNaN(asDate)) {
44
- return asDate;
45
- }
46
- }
47
- if (typeof body.expires_in === "number") {
48
- return Date.now() + body.expires_in * 1000;
49
- }
50
- throw new Error(`Failed to parse token expiration from body. expires_in="${body.expires_in}", expires_on="${body.expires_on}"`);
51
- }
52
- /**
53
- * Given a token response, return the expiration timestamp as the number of milliseconds from the Unix epoch.
54
- * @param body - A parsed response body from the authentication endpoint.
55
- */
56
- export function parseRefreshTimestamp(body) {
57
- if (body.refresh_on) {
58
- if (typeof body.refresh_on === "number") {
59
- return body.refresh_on * 1000;
60
- }
61
- if (typeof body.refresh_on === "string") {
62
- const asNumber = +body.refresh_on;
63
- if (!isNaN(asNumber)) {
64
- return asNumber * 1000;
65
- }
66
- const asDate = Date.parse(body.refresh_on);
67
- if (!isNaN(asDate)) {
68
- return asDate;
69
- }
70
- }
71
- throw new Error(`Failed to parse refresh_on from body. refresh_on="${body.refresh_on}"`);
72
- }
73
- else {
74
- return undefined;
75
- }
76
- }
77
- //# sourceMappingURL=utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/credentials/managedIdentityCredential/utils.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEjD;;;;;;;;GAQG;AACH,MAAM,UAAU,mBAAmB,CAAC,MAAyB;IAC3D,IAAI,KAAK,GAAG,EAAE,CAAC;IACf,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC;SAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE,CAAC;QACtC,KAAK,GAAG,MAAM,CAAC;IACjB,CAAC;IAED,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,CAAC;QACxC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC,CAAC;AAChE,CAAC;AAeD;;;GAGG;AACH,MAAM,UAAU,wBAAwB,CAAC,IAA6B;IACpE,IAAI,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;QACxC,OAAO,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IAChC,CAAC;IAED,IAAI,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;QACxC,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;YACrB,OAAO,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;YACnB,OAAO,MAAM,CAAC;QAChB,CAAC;IACH,CAAC;IAED,IAAI,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;QACxC,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IAC7C,CAAC;IAED,MAAM,IAAI,KAAK,CACb,2DAA2D,IAAI,CAAC,UAAU,kBAAkB,IAAI,CAAC,UAAU,GAAG,CAC/G,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,qBAAqB,CAAC,IAA6B;IACjE,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,IAAI,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAChC,CAAC;QAED,IAAI,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;YACxC,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;YAClC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACrB,OAAO,QAAQ,GAAG,IAAI,CAAC;YACzB,CAAC;YAED,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC3C,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;gBACnB,OAAO,MAAM,CAAC;YAChB,CAAC;QACH,CAAC;QACD,MAAM,IAAI,KAAK,CAAC,qDAAqD,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IAC3F,CAAC;SAAM,CAAC;QACN,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { DefaultScopeSuffix } from \"./constants\";\n\n/**\n * Most MSIs send requests to the IMDS endpoint, or a similar endpoint.\n * These are GET requests that require sending a `resource` parameter on the query.\n * This resource can be derived from the scopes received through the getToken call, as long as only one scope is received.\n * Multiple scopes assume that the resulting token will have access to multiple resources, which won't be the case.\n *\n * For that reason, when we encounter multiple scopes, we return undefined.\n * It's up to the individual MSI implementations to throw the errors (which helps us provide less generic errors).\n */\nexport function mapScopesToResource(scopes: string | string[]): string | undefined {\n let scope = \"\";\n if (Array.isArray(scopes)) {\n if (scopes.length !== 1) {\n return;\n }\n\n scope = scopes[0];\n } else if (typeof scopes === \"string\") {\n scope = scopes;\n }\n\n if (!scope.endsWith(DefaultScopeSuffix)) {\n return scope;\n }\n\n return scope.substr(0, scope.lastIndexOf(DefaultScopeSuffix));\n}\n\n/**\n * Internal type roughly matching the raw responses of the authentication endpoints.\n *\n * @internal\n */\nexport interface TokenResponseParsedBody {\n access_token?: string;\n refresh_token?: string;\n expires_in: number;\n expires_on?: number | string;\n refresh_on?: number | string;\n}\n\n/**\n * Given a token response, return the expiration timestamp as the number of milliseconds from the Unix epoch.\n * @param body - A parsed response body from the authentication endpoint.\n */\nexport function parseExpirationTimestamp(body: TokenResponseParsedBody): number {\n if (typeof body.expires_on === \"number\") {\n return body.expires_on * 1000;\n }\n\n if (typeof body.expires_on === \"string\") {\n const asNumber = +body.expires_on;\n if (!isNaN(asNumber)) {\n return asNumber * 1000;\n }\n\n const asDate = Date.parse(body.expires_on);\n if (!isNaN(asDate)) {\n return asDate;\n }\n }\n\n if (typeof body.expires_in === \"number\") {\n return Date.now() + body.expires_in * 1000;\n }\n\n throw new Error(\n `Failed to parse token expiration from body. expires_in=\"${body.expires_in}\", expires_on=\"${body.expires_on}\"`,\n );\n}\n\n/**\n * Given a token response, return the expiration timestamp as the number of milliseconds from the Unix epoch.\n * @param body - A parsed response body from the authentication endpoint.\n */\nexport function parseRefreshTimestamp(body: TokenResponseParsedBody): number | undefined {\n if (body.refresh_on) {\n if (typeof body.refresh_on === \"number\") {\n return body.refresh_on * 1000;\n }\n\n if (typeof body.refresh_on === \"string\") {\n const asNumber = +body.refresh_on;\n if (!isNaN(asNumber)) {\n return asNumber * 1000;\n }\n\n const asDate = Date.parse(body.refresh_on);\n if (!isNaN(asDate)) {\n return asDate;\n }\n }\n throw new Error(`Failed to parse refresh_on from body. refresh_on=\"${body.refresh_on}\"`);\n } else {\n return undefined;\n }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"multiTenantTokenCredentialOptions.js","sourceRoot":"","sources":["../../../src/credentials/multiTenantTokenCredentialOptions.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { TokenCredentialOptions } from \"../tokenCredentialOptions\";\n\n/**\n * Options for multi-tenant applications which allows for additionally allowed tenants.\n */\nexport interface MultiTenantTokenCredentialOptions extends TokenCredentialOptions {\n /**\n * For multi-tenant applications, specifies additional tenants for which the credential may acquire tokens.\n * Add the wildcard value \"*\" to allow the credential to acquire tokens for any tenant the application is installed.\n */\n additionallyAllowedTenants?: string[];\n}\n"]}
@@ -1,23 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import { credentialLogger, formatError } from "../util/logging";
4
- const credentialName = "OnBehalfOfCredential";
5
- const BrowserNotSupportedError = new Error(`${credentialName}: Not supported in the browser.`);
6
- const logger = credentialLogger(credentialName);
7
- /**
8
- * Enables authentication to Microsoft Entra ID using the [On Behalf Of flow](https://learn.microsoft.com/entra/identity-platform/v2-oauth2-on-behalf-of-flow).
9
- */
10
- export class OnBehalfOfCredential {
11
- /**
12
- * Only available in Node.js
13
- */
14
- constructor() {
15
- logger.info(formatError("", BrowserNotSupportedError));
16
- throw BrowserNotSupportedError;
17
- }
18
- getToken() {
19
- logger.getToken.info(formatError("", BrowserNotSupportedError));
20
- throw BrowserNotSupportedError;
21
- }
22
- }
23
- //# sourceMappingURL=onBehalfOfCredential.browser.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"onBehalfOfCredential.browser.js","sourceRoot":"","sources":["../../../src/credentials/onBehalfOfCredential.browser.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAGlC,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAEhE,MAAM,cAAc,GAAG,sBAAsB,CAAC;AAC9C,MAAM,wBAAwB,GAAG,IAAI,KAAK,CAAC,GAAG,cAAc,iCAAiC,CAAC,CAAC;AAC/F,MAAM,MAAM,GAAG,gBAAgB,CAAC,cAAc,CAAC,CAAC;AAEhD;;GAEG;AACH,MAAM,OAAO,oBAAoB;IAC/B;;OAEG;IACH;QACE,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,EAAE,wBAAwB,CAAC,CAAC,CAAC;QACvD,MAAM,wBAAwB,CAAC;IACjC,CAAC;IAEM,QAAQ;QACb,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,EAAE,wBAAwB,CAAC,CAAC,CAAC;QAChE,MAAM,wBAAwB,CAAC;IACjC,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { AccessToken, TokenCredential } from \"@azure/core-auth\";\nimport { credentialLogger, formatError } from \"../util/logging\";\n\nconst credentialName = \"OnBehalfOfCredential\";\nconst BrowserNotSupportedError = new Error(`${credentialName}: Not supported in the browser.`);\nconst logger = credentialLogger(credentialName);\n\n/**\n * Enables authentication to Microsoft Entra ID using the [On Behalf Of flow](https://learn.microsoft.com/entra/identity-platform/v2-oauth2-on-behalf-of-flow).\n */\nexport class OnBehalfOfCredential implements TokenCredential {\n /**\n * Only available in Node.js\n */\n constructor() {\n logger.info(formatError(\"\", BrowserNotSupportedError));\n throw BrowserNotSupportedError;\n }\n\n public getToken(): Promise<AccessToken | null> {\n logger.getToken.info(formatError(\"\", BrowserNotSupportedError));\n throw BrowserNotSupportedError;\n }\n}\n"]}
@@ -1,112 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import { createMsalClient } from "../msal/nodeFlows/msalClient";
4
- import { credentialLogger, formatError } from "../util/logging";
5
- import { processMultiTenantRequest, resolveAdditionallyAllowedTenantIds, } from "../util/tenantIdUtils";
6
- import { CredentialUnavailableError } from "../errors";
7
- import { createHash } from "node:crypto";
8
- import { ensureScopes } from "../util/scopeUtils";
9
- import { readFile } from "node:fs/promises";
10
- import { tracingClient } from "../util/tracing";
11
- const credentialName = "OnBehalfOfCredential";
12
- const logger = credentialLogger(credentialName);
13
- /**
14
- * Enables authentication to Microsoft Entra ID using the [On Behalf Of flow](https://learn.microsoft.com/entra/identity-platform/v2-oauth2-on-behalf-of-flow).
15
- */
16
- export class OnBehalfOfCredential {
17
- constructor(options) {
18
- const { clientSecret } = options;
19
- const { certificatePath, sendCertificateChain } = options;
20
- const { getAssertion } = options;
21
- const { tenantId, clientId, userAssertionToken, additionallyAllowedTenants: additionallyAllowedTenantIds, } = options;
22
- if (!tenantId) {
23
- throw new CredentialUnavailableError(`${credentialName}: tenantId is a required parameter. To troubleshoot, visit https://aka.ms/azsdk/js/identity/serviceprincipalauthentication/troubleshoot.`);
24
- }
25
- if (!clientId) {
26
- throw new CredentialUnavailableError(`${credentialName}: clientId is a required parameter. To troubleshoot, visit https://aka.ms/azsdk/js/identity/serviceprincipalauthentication/troubleshoot.`);
27
- }
28
- if (!clientSecret && !certificatePath && !getAssertion) {
29
- throw new CredentialUnavailableError(`${credentialName}: You must provide one of clientSecret, certificatePath, or a getAssertion callback but none were provided. To troubleshoot, visit https://aka.ms/azsdk/js/identity/serviceprincipalauthentication/troubleshoot.`);
30
- }
31
- if (!userAssertionToken) {
32
- throw new CredentialUnavailableError(`${credentialName}: userAssertionToken is a required parameter. To troubleshoot, visit https://aka.ms/azsdk/js/identity/serviceprincipalauthentication/troubleshoot.`);
33
- }
34
- this.certificatePath = certificatePath;
35
- this.clientSecret = clientSecret;
36
- this.userAssertionToken = userAssertionToken;
37
- this.sendCertificateChain = sendCertificateChain;
38
- this.clientAssertion = getAssertion;
39
- this.tenantId = tenantId;
40
- this.additionallyAllowedTenantIds = resolveAdditionallyAllowedTenantIds(additionallyAllowedTenantIds);
41
- this.msalClient = createMsalClient(clientId, this.tenantId, Object.assign(Object.assign({}, options), { logger, tokenCredentialOptions: options }));
42
- }
43
- /**
44
- * Authenticates with Microsoft Entra ID and returns an access token if successful.
45
- * If authentication fails, a {@link CredentialUnavailableError} will be thrown with the details of the failure.
46
- *
47
- * @param scopes - The list of scopes for which the token will have access.
48
- * @param options - The options used to configure the underlying network requests.
49
- */
50
- async getToken(scopes, options = {}) {
51
- return tracingClient.withSpan(`${credentialName}.getToken`, options, async (newOptions) => {
52
- newOptions.tenantId = processMultiTenantRequest(this.tenantId, newOptions, this.additionallyAllowedTenantIds, logger);
53
- const arrayScopes = ensureScopes(scopes);
54
- if (this.certificatePath) {
55
- const clientCertificate = await this.buildClientCertificate(this.certificatePath);
56
- return this.msalClient.getTokenOnBehalfOf(arrayScopes, this.userAssertionToken, clientCertificate, newOptions);
57
- }
58
- else if (this.clientSecret) {
59
- return this.msalClient.getTokenOnBehalfOf(arrayScopes, this.userAssertionToken, this.clientSecret, options);
60
- }
61
- else if (this.clientAssertion) {
62
- return this.msalClient.getTokenOnBehalfOf(arrayScopes, this.userAssertionToken, this.clientAssertion, options);
63
- }
64
- else {
65
- // this is an invalid scenario and is a bug, as the constructor should have thrown an error if neither clientSecret nor certificatePath nor clientAssertion were provided
66
- throw new Error("Expected either clientSecret or certificatePath or clientAssertion to be defined.");
67
- }
68
- });
69
- }
70
- async buildClientCertificate(certificatePath) {
71
- try {
72
- const parts = await this.parseCertificate({ certificatePath }, this.sendCertificateChain);
73
- return {
74
- thumbprint: parts.thumbprint,
75
- privateKey: parts.certificateContents,
76
- x5c: parts.x5c,
77
- };
78
- }
79
- catch (error) {
80
- logger.info(formatError("", error));
81
- throw error;
82
- }
83
- }
84
- async parseCertificate(configuration, sendCertificateChain) {
85
- const certificatePath = configuration.certificatePath;
86
- const certificateContents = await readFile(certificatePath, "utf8");
87
- const x5c = sendCertificateChain ? certificateContents : undefined;
88
- const certificatePattern = /(-+BEGIN CERTIFICATE-+)(\n\r?|\r\n?)([A-Za-z0-9+/\n\r]+=*)(\n\r?|\r\n?)(-+END CERTIFICATE-+)/g;
89
- const publicKeys = [];
90
- // Match all possible certificates, in the order they are in the file. These will form the chain that is used for x5c
91
- let match;
92
- do {
93
- match = certificatePattern.exec(certificateContents);
94
- if (match) {
95
- publicKeys.push(match[3]);
96
- }
97
- } while (match);
98
- if (publicKeys.length === 0) {
99
- throw new Error("The file at the specified path does not contain a PEM-encoded certificate.");
100
- }
101
- const thumbprint = createHash("sha1")
102
- .update(Buffer.from(publicKeys[0], "base64"))
103
- .digest("hex")
104
- .toUpperCase();
105
- return {
106
- certificateContents,
107
- thumbprint,
108
- x5c,
109
- };
110
- }
111
- }
112
- //# sourceMappingURL=onBehalfOfCredential.js.map