UNPKG

amazon-cognito-identity-js-typescript

Version:

Amazon Cognito Identity Provider JavaScript SDK

68 lines (60 loc) 1.89 kB
/*! * Copyright 2016 Amazon.com, * Inc. or its affiliates. All Rights Reserved. * * Licensed under the Amazon Software License (the "License"). * You may not use this file except in compliance with the * License. A copy of the License is located at * * http://aws.amazon.com/asl/ * * or in the "license" file accompanying this file. This file is * distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR * CONDITIONS OF ANY KIND, express or implied. See the License * for the specific language governing permissions and * limitations under the License. */ /** @class */ export default class CognitoUserSession { /** * Constructs a new CognitoUserSession object * @param {string} IdToken The session's Id token. * @param {string=} RefreshToken The session's refresh token. * @param {string} AccessToken The session's access token. */ constructor({ IdToken, RefreshToken, AccessToken } = {}) { if (AccessToken == null || IdToken == null) { throw new Error('Id token and Access Token must be present.'); } this.idToken = IdToken; this.refreshToken = RefreshToken; this.accessToken = AccessToken; } /** * @returns {CognitoIdToken} the session's Id token */ getIdToken() { return this.idToken; } /** * @returns {CognitoRefreshToken} the session's refresh token */ getRefreshToken() { return this.refreshToken; } /** * @returns {CognitoAccessToken} the session's access token */ getAccessToken() { return this.accessToken; } /** * Checks to see if the session is still valid based on session expiry information found * in tokens and the current time * @returns {boolean} if the session is still valid */ isValid() { const now = Math.floor(new Date() / 1000); return now < this.accessToken.getExpiration() && now < this.idToken.getExpiration(); } }