UNPKG

@okta/okta-auth-js

Version:
83 lines (66 loc) 2.38 kB
"use strict"; exports.renewToken = renewToken; var _errors = require("../errors"); var _types = require("./types"); var _getWithoutPrompt = require("./getWithoutPrompt"); var _renewTokensWithRefresh = require("./renewTokensWithRefresh"); /*! * Copyright (c) 2015-present, Okta, Inc. and/or its affiliates. All rights reserved. * The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.") * * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0. * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * * See the License for the specific language governing permissions and limitations under the License. * */ function throwInvalidTokenError() { throw new _errors.AuthSdkError('Renew must be passed a token with an array of scopes and an accessToken or idToken'); } // Multiple tokens may have come back. Return only the token which was requested. function getSingleToken(originalToken, tokens) { if ((0, _types.isIDToken)(originalToken)) { return tokens.idToken; } if ((0, _types.isAccessToken)(originalToken)) { return tokens.accessToken; } throwInvalidTokenError(); } // If we have a refresh token, renew using that, otherwise getWithoutPrompt async function renewToken(sdk, token) { if (!(0, _types.isIDToken)(token) && !(0, _types.isAccessToken)(token)) { throwInvalidTokenError(); } let tokens = sdk.tokenManager.getTokensSync(); if (tokens.refreshToken) { tokens = await (0, _renewTokensWithRefresh.renewTokensWithRefresh)(sdk, { scopes: token.scopes }, tokens.refreshToken); return getSingleToken(token, tokens); } var responseType; if (sdk.options.pkce) { responseType = 'code'; } else if ((0, _types.isAccessToken)(token)) { responseType = 'token'; } else { responseType = 'id_token'; } const { scopes, authorizeUrl, userinfoUrl, issuer } = token; return (0, _getWithoutPrompt.getWithoutPrompt)(sdk, { responseType, scopes, authorizeUrl, userinfoUrl, issuer }).then(function (res) { return getSingleToken(token, res.tokens); }); } //# sourceMappingURL=renewToken.js.map