@okta/okta-auth-js
Version:
The Okta Auth SDK
56 lines (52 loc) • 2.01 kB
JavaScript
exports.handleInteractionCodeRedirect = handleInteractionCodeRedirect;
var _errors = require("../errors");
/*!
* 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.
*/
async function handleInteractionCodeRedirect(authClient, url) {
const meta = authClient.transactionManager.load();
if (!meta) {
throw new _errors.AuthSdkError('No transaction data was found in storage');
}
const {
codeVerifier,
state: savedState
} = meta;
const {
searchParams
// URL API has been added to the polyfill
// eslint-disable-next-line compat/compat
} = new URL(url);
const state = searchParams.get('state');
const interactionCode = searchParams.get('interaction_code');
// Error handling
const error = searchParams.get('error');
if (error) {
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
throw new _errors.OAuthError(error, searchParams.get('error_description'));
}
if (state !== savedState) {
throw new _errors.AuthSdkError('State in redirect uri does not match with transaction state');
}
if (!interactionCode) {
throw new _errors.AuthSdkError('Unable to parse interaction_code from the url');
}
// Save tokens to storage
const {
tokens
} = await authClient.token.exchangeCodeForTokens({
interactionCode,
codeVerifier
});
authClient.tokenManager.setTokens(tokens);
}
//# sourceMappingURL=handleInteractionCodeRedirect.js.map
;