UNPKG

@okta/okta-auth-js

Version:
69 lines (65 loc) 2.58 kB
/*! * 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. */ import AuthSdkError from '../errors/AuthSdkError.js'; import '../errors/WWWAuthError.js'; import { getWellKnown } from './endpoints/well-known.js'; import { btoa as b } from '../crypto/browser.js'; import { toQueryString } from '../util/url.js'; import { post } from '../http/request.js'; import 'tiny-emitter'; import 'js-cookie'; import 'cross-fetch'; import { TokenKind } from './types/Token.js'; const hintMap = { accessToken: 'access_token', idToken: 'id_token', refreshToken: 'refresh_token' }; async function oidcIntrospect(sdk, kind, token) { var _a; let issuer; let clientId = sdk.options.clientId; let clientSecret = sdk.options.clientSecret; if (!token) { token = sdk.tokenManager.getTokens()[kind]; } if (!token) { throw new AuthSdkError(`unable to find ${kind} in storage or fn params`); } if (kind !== TokenKind.ACCESS) { issuer = token === null || token === void 0 ? void 0 : token.issuer; } else { issuer = (_a = token === null || token === void 0 ? void 0 : token.claims) === null || _a === void 0 ? void 0 : _a.iss; } issuer = issuer || sdk.options.issuer; if (!clientId) { throw new AuthSdkError('A clientId must be specified in the OktaAuth constructor to introspect a token'); } if (!issuer) { throw new AuthSdkError('Unable to find issuer'); } const { introspection_endpoint: introspectUrl } = await getWellKnown(sdk, issuer); const authHeader = clientSecret ? b(`${clientId}:${clientSecret}`) : b(clientId); const args = toQueryString({ token_type_hint: hintMap[kind], token: token[kind] }).slice(1); return post(sdk, introspectUrl, args, { headers: { 'Content-Type': 'application/x-www-form-urlencoded', 'Authorization': 'Basic ' + authHeader } }); } export { oidcIntrospect }; //# sourceMappingURL=introspect.js.map