UNPKG

trimble-connect-sdk

Version:

Trimble Connect SDK for JavaScript

82 lines 12.4 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.TIDCredentials = void 0; const credentials_1 = require("./credentials"); const tid_1 = require("./tid"); class TIDCredentials extends credentials_1.Credentials { constructor(params, userCredentials, onRefreshed, onInvalidated) { super(); this.params = params; this.userCredentials = userCredentials; this.onRefreshed = onRefreshed; this.onInvalidated = onInvalidated; this.expired = true; this.service = new tid_1.TID(params); } refresh() { if (this.ongoingTokenRefresh !== undefined) { return this.ongoingTokenRefresh; } this.ongoingTokenRefresh = this.refreshToken() .then(() => (this.ongoingTokenRefresh = undefined)) .catch((e) => { this.ongoingTokenRefresh = undefined; throw e; }); return this.ongoingTokenRefresh; } invalidToken() { return !this.tokens; } getOAuthRedirect() { return this.service.getOAuthRedirect(); } exchangeCode(code) { return __awaiter(this, void 0, void 0, function* () { const response = yield this.service.exchangeCode(code); this.tokens = response.data; this.expired = false; this.expireTime = new Date(); this.expireTime.setSeconds(this.expireTime.getSeconds() + this.tokens.expires_in); }); } refreshToken() { return __awaiter(this, void 0, void 0, function* () { let error; if (this.tokens && this.tokens.refresh_token) { try { const response = yield this.service.refresh(this.tokens.refresh_token); this.tokens = response.data; } catch (e) { error = e; } } if (!(this.tokens && this.tokens.refresh_token) || error) { if (this.onInvalidated) { this.onInvalidated(this.getOAuthRedirect()); return; } else { throw new Error('Cannot acquire TID token.'); } } this.expireTime = new Date(); this.expireTime.setSeconds(this.expireTime.getSeconds() + this.tokens.expires_in); if (this.onRefreshed) { this.onRefreshed(this); } }); } } exports.TIDCredentials = TIDCredentials; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tid_credentials.js","sourceRoot":"./","sources":["tid_credentials.ts"],"names":[],"mappings":"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","sourcesContent":["import { Credentials } from './credentials';\nimport { AuthResponse, TID, TIDConfig } from './tid';\n\n// tslint:disable-next-line:no-empty-interface\nexport interface TIDCredentialsParams extends TIDConfig {}\n\n/**\n * User credentials can be used only for user accounts with 2FA disabled, such as test user accounts.\n */\nexport interface TIDUserCredentials {\n  password: string;\n  username: string;\n}\n\n/**\n * Service credentials that must be attached to authenticate each request.\n * Occasionally credentials can expire in the middle of a long-running application.\n */\nexport class TIDCredentials extends Credentials {\n  public tokens?: AuthResponse;\n  private readonly service: TID;\n  private ongoingTokenRefresh: Promise<void> | undefined;\n\n  /**\n   * Creates a TIDCredentials object with a given set of credential information as positional arguments.\n   * @param {TIDCredentialsParams} params The TID Credentials configuration options.\n   * @param {TIDUserCredentials} [userCredentials] The user credentials. Optional.\n   * @param {(TIDCredentials) => void} [onRefreshed] Called when TID tokens are refreshed. Optional.\n   * @param {(string) => void} [onInvalidated] Called when TID tokens are not valid anymore. Optional.\n   * @example Creating a new credentials object\n   *   credentials = new TC.TIDCredentials({\n   *       serviceUri: \"https://id.trimble.com/\",\n   *       clientId: \"xxx\",\n   *       clientSecret: \"yyy\",\n   *       appName: 'zzz',\n   *       redirectUri: 'https://aaa.com',\n   *     },\n   *     { username: \"name\", password: \"pass\" }\n   *   )\n   */\n  constructor(\n    public readonly params: TIDCredentialsParams,\n    public userCredentials?: TIDUserCredentials,\n    public readonly onRefreshed?: (tidCredentials: TIDCredentials) => void,\n    public readonly onInvalidated?: (redirectUri: string) => void\n  ) {\n    super();\n    this.expired = true;\n    this.service = new TID(params);\n  }\n\n  /**\n   * Refreshes the credentials, ensuring only one such operation is in progress at a time\n   * Users should call get() before attempting to forcibly refresh credentials.\n   * @note Subclasses should override this class to reset the {token} on the credentials object.\n   * @see get\n   */\n  public refresh(): Promise<void> {\n    if (this.ongoingTokenRefresh !== undefined) {\n      // token refreshing is already in progress\n      return this.ongoingTokenRefresh;\n    }\n\n    // start a new token refresh call and store it in the promise such that\n    // further calls are not started until this finishes\n    this.ongoingTokenRefresh = this.refreshToken()\n      .then(() => (this.ongoingTokenRefresh = undefined))\n      .catch((e) => {\n        this.ongoingTokenRefresh = undefined;\n        throw e;\n      });\n\n    return this.ongoingTokenRefresh;\n  }\n\n  /**\n   * Returns whether the token invalid\n   */\n  public invalidToken(): boolean {\n    return !this.tokens;\n  }\n\n  /**\n   * Returns the authentication URI where the user should be redirected when authenticating.\n   */\n  public getOAuthRedirect(): string {\n    return this.service.getOAuthRedirect();\n  }\n\n  /**\n   * Exchanges the authorization code with the identity server for the auth grants.\n   * Sets the auth grants into to service credentials.\n   */\n  public async exchangeCode(code: string): Promise<void> {\n    const response = await this.service.exchangeCode(code);\n    this.tokens = response.data;\n    this.expired = false;\n    this.expireTime = new Date();\n    this.expireTime.setSeconds(\n      this.expireTime.getSeconds() + this.tokens.expires_in\n    );\n  }\n\n  /**\n   * Perform refreshing the credentials\n   */\n  private async refreshToken(): Promise<void> {\n    let error: Error | undefined;\n    // try refresh token first if it exists\n    if (this.tokens && this.tokens.refresh_token) {\n      try {\n        const response = await this.service.refresh(this.tokens.refresh_token);\n        this.tokens = response.data;\n      } catch (e: any) {\n        error = e;\n      }\n    }\n\n    // session is invalid if we do not have valid auth grants, so call callback or throw error.\n    if (!(this.tokens && this.tokens.refresh_token) || error) {\n      if (this.onInvalidated) {\n        this.onInvalidated(this.getOAuthRedirect());\n        return;\n      } else {\n        throw new Error('Cannot acquire TID token.');\n      }\n    }\n\n    this.expireTime = new Date();\n    this.expireTime.setSeconds(\n      this.expireTime.getSeconds() + this.tokens.expires_in\n    );\n\n    if (this.onRefreshed) {\n      this.onRefreshed(this);\n    }\n  }\n}\n"]}