UNPKG

@okta/okta-auth-js

Version:
71 lines (67 loc) 2.49 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 { omit, getLink } from '../util/object.js'; import { toQueryString } from '../util/url.js'; import '../errors/WWWAuthError.js'; import { get, post, httpRequest } from '../http/request.js'; import 'tiny-emitter'; import 'js-cookie'; import 'cross-fetch'; function sessionExists(sdk) { return sdk.session.get() .then(function (res) { if (res.status === 'ACTIVE') { return true; } return false; }) .catch(function () { return false; }); } function getSession(sdk) { return get(sdk, '/api/v1/sessions/me', { withCredentials: true }) .then(function (session) { var res = omit(session, '_links'); res.refresh = function () { return post(sdk, getLink(session, 'refresh').href, {}, { withCredentials: true }); }; res.user = function () { return get(sdk, getLink(session, 'user').href, { withCredentials: true }); }; return res; }) .catch(function () { return { status: 'INACTIVE' }; }); } function closeSession(sdk) { return httpRequest(sdk, { url: sdk.getIssuerOrigin() + '/api/v1/sessions/me', method: 'DELETE', withCredentials: true }); } function refreshSession(sdk) { return post(sdk, '/api/v1/sessions/me/lifecycle/refresh', {}, { withCredentials: true }); } function setCookieAndRedirect(sdk, sessionToken, redirectUrl) { redirectUrl = redirectUrl || window.location.href; window.location.assign(sdk.getIssuerOrigin() + '/login/sessionCookieRedirect' + toQueryString({ checkAccountSetupComplete: true, token: sessionToken, redirectUrl: redirectUrl })); } export { closeSession, getSession, refreshSession, sessionExists, setCookieAndRedirect }; //# sourceMappingURL=api.js.map