trimble-connect-sdk
Version:
Trimble Connect SDK for JavaScript
82 lines • 12.4 kB
JavaScript
"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"]}