@okta/okta-auth-js
Version:
The Okta Auth SDK
67 lines (52 loc) • 2.3 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
exports.revokeToken = revokeToken;
var _http = require("../http");
var _util = require("../util");
var _oauth = require("./util/oauth");
var _crypto = require("../crypto");
var _AuthSdkError = _interopRequireDefault(require("../errors/AuthSdkError"));
/*!
* 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.
*
*/
/* eslint complexity:[0,8] */
// refresh tokens have precedence to be revoked if no token is specified
async function revokeToken(sdk, token) {
let accessToken = '';
let refreshToken = '';
if (token) {
accessToken = token.accessToken;
refreshToken = token.refreshToken;
}
if (!accessToken && !refreshToken) {
throw new _AuthSdkError.default('A valid access or refresh token object is required');
}
var clientId = sdk.options.clientId;
var clientSecret = sdk.options.clientSecret;
if (!clientId) {
throw new _AuthSdkError.default('A clientId must be specified in the OktaAuth constructor to revoke a token');
} // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
var revokeUrl = (0, _oauth.getOAuthUrls)(sdk).revokeUrl;
var args = (0, _util.toQueryString)({
// eslint-disable-next-line camelcase
token_type_hint: refreshToken ? 'refresh_token' : 'access_token',
token: refreshToken || accessToken
}).slice(1);
var creds = clientSecret ? (0, _crypto.btoa)(`${clientId}:${clientSecret}`) : (0, _crypto.btoa)(clientId);
return (0, _http.post)(sdk, revokeUrl, args, {
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Authorization': 'Basic ' + creds
}
});
}
//# sourceMappingURL=revokeToken.js.map
;