UNPKG

@azure/msal-browser

Version:
117 lines (108 loc) 4.06 kB
/* * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the MIT License. */ import { StandardInteractionClient } from "./StandardInteractionClient"; import { CommonSilentFlowRequest, ServerTelemetryManager, RefreshTokenClient, AuthError, AzureCloudOptions, PerformanceEvents, invokeAsync, AccountInfo, } from "@azure/msal-common"; import { ApiId } from "../utils/BrowserConstants"; import { createBrowserAuthError, BrowserAuthErrorCodes, } from "../error/BrowserAuthError"; import { AuthenticationResult } from "../response/AuthenticationResult"; import { initializeBaseRequest } from "../request/RequestHelpers"; export class SilentRefreshClient extends StandardInteractionClient { /** * Exchanges the refresh token for new tokens * @param request */ async acquireToken( request: CommonSilentFlowRequest ): Promise<AuthenticationResult> { this.performanceClient.addQueueMeasurement( PerformanceEvents.SilentRefreshClientAcquireToken, request.correlationId ); const baseRequest = await invokeAsync( initializeBaseRequest, PerformanceEvents.InitializeBaseRequest, this.logger, this.performanceClient, request.correlationId )(request, this.config, this.performanceClient, this.logger); const silentRequest: CommonSilentFlowRequest = { ...request, ...baseRequest, }; if (request.redirectUri) { // Make sure any passed redirectUri is converted to an absolute URL - redirectUri is not a required parameter for refresh token redemption so only include if explicitly provided silentRequest.redirectUri = this.getRedirectUri( request.redirectUri ); } const serverTelemetryManager = this.initializeServerTelemetryManager( ApiId.acquireTokenSilent_silentFlow ); const refreshTokenClient = await this.createRefreshTokenClient( serverTelemetryManager, silentRequest.authority, silentRequest.azureCloudOptions, silentRequest.account ); // Send request to renew token. Auth module will throw errors if token cannot be renewed. return invokeAsync( refreshTokenClient.acquireTokenByRefreshToken.bind( refreshTokenClient ), PerformanceEvents.RefreshTokenClientAcquireTokenByRefreshToken, this.logger, this.performanceClient, request.correlationId )(silentRequest).catch((e: AuthError) => { (e as AuthError).setCorrelationId(this.correlationId); serverTelemetryManager.cacheFailedRequest(e); throw e; }) as Promise<AuthenticationResult>; } /** * Currently Unsupported */ logout(): Promise<void> { // Synchronous so we must reject return Promise.reject( createBrowserAuthError( BrowserAuthErrorCodes.silentLogoutUnsupported ) ); } /** * Creates a Refresh Client with the given authority, or the default authority. * @param serverTelemetryManager * @param authorityUrl */ protected async createRefreshTokenClient( serverTelemetryManager: ServerTelemetryManager, authorityUrl?: string, azureCloudOptions?: AzureCloudOptions, account?: AccountInfo ): Promise<RefreshTokenClient> { // Create auth module. const clientConfig = await invokeAsync( this.getClientConfiguration.bind(this), PerformanceEvents.StandardInteractionClientGetClientConfiguration, this.logger, this.performanceClient, this.correlationId )(serverTelemetryManager, authorityUrl, azureCloudOptions, account); return new RefreshTokenClient(clientConfig, this.performanceClient); } }