@cloudbase/oauth 2.4.4-beta.0 → 2.5.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/.eslintrc.js +15 -0
  2. package/dist/cjs/auth/apis.d.ts +3 -3
  3. package/dist/cjs/auth/apis.js +69 -69
  4. package/dist/cjs/captcha/captcha.d.ts +9 -9
  5. package/dist/cjs/captcha/captcha.js +43 -46
  6. package/dist/cjs/index.d.ts +3 -3
  7. package/dist/cjs/index.js +6 -6
  8. package/dist/cjs/oauth2client/interface.d.ts +1 -1
  9. package/dist/cjs/oauth2client/interface.js +1 -1
  10. package/dist/cjs/oauth2client/models.js +1 -1
  11. package/dist/cjs/oauth2client/oauth2client.d.ts +31 -31
  12. package/dist/cjs/oauth2client/oauth2client.js +229 -229
  13. package/dist/cjs/utils/function/single-promise.d.ts +2 -2
  14. package/dist/cjs/utils/function/single-promise.js +40 -33
  15. package/dist/cjs/utils/uuid.js +2 -2
  16. package/dist/esm/auth/apis.d.ts +3 -3
  17. package/dist/esm/auth/apis.js +69 -69
  18. package/dist/esm/captcha/captcha.d.ts +9 -9
  19. package/dist/esm/captcha/captcha.js +44 -47
  20. package/dist/esm/index.d.ts +3 -3
  21. package/dist/esm/index.js +5 -5
  22. package/dist/esm/oauth2client/interface.d.ts +1 -1
  23. package/dist/esm/oauth2client/interface.js +1 -1
  24. package/dist/esm/oauth2client/models.js +1 -1
  25. package/dist/esm/oauth2client/oauth2client.d.ts +31 -31
  26. package/dist/esm/oauth2client/oauth2client.js +229 -229
  27. package/dist/esm/utils/function/single-promise.d.ts +2 -2
  28. package/dist/esm/utils/function/single-promise.js +40 -33
  29. package/dist/esm/utils/uuid.js +2 -2
  30. package/package.json +13 -6
  31. package/src/auth/apis.ts +135 -158
  32. package/src/captcha/captcha.ts +71 -78
  33. package/src/index.ts +13 -14
  34. package/src/oauth2client/interface.ts +5 -5
  35. package/src/oauth2client/models.ts +38 -38
  36. package/src/oauth2client/oauth2client.ts +255 -268
  37. package/src/utils/function/single-promise.ts +22 -21
  38. package/src/utils/uuid.ts +4 -4
  39. package/.eslintrc +0 -26
@@ -51,56 +51,58 @@ import { SinglePromise } from '../utils/function/single-promise';
51
51
  var RequestIdHeaderName = 'x-request-id';
52
52
  var DeviceIdHeaderName = 'x-device-id';
53
53
  var DeviceIdSectionName = 'device_id';
54
- export var defaultRequest = function (url, options) { return __awaiter(void 0, void 0, void 0, function () {
55
- var result, responseError, copyOptions, responseResult, jsonResponse, error_1;
56
- return __generator(this, function (_a) {
57
- switch (_a.label) {
58
- case 0:
59
- result = null;
60
- responseError = null;
61
- _a.label = 1;
62
- case 1:
63
- _a.trys.push([1, 4, , 5]);
64
- copyOptions = Object.assign({}, options);
65
- if (!copyOptions.method) {
66
- copyOptions.method = 'GET';
67
- }
68
- if (copyOptions.body && typeof copyOptions.body !== 'string') {
69
- copyOptions.body = JSON.stringify(copyOptions.body);
70
- }
71
- return [4, fetch(url, copyOptions)];
72
- case 2:
73
- responseResult = _a.sent();
74
- return [4, responseResult.json()];
75
- case 3:
76
- jsonResponse = _a.sent();
77
- if (jsonResponse === null || jsonResponse === void 0 ? void 0 : jsonResponse.error) {
78
- responseError = jsonResponse;
79
- responseError.error_uri = new URL(url).pathname;
80
- }
81
- else {
82
- result = jsonResponse;
83
- }
84
- return [3, 5];
85
- case 4:
86
- error_1 = _a.sent();
87
- responseError = {
88
- error: ErrorType.UNREACHABLE,
89
- error_description: error_1.message,
90
- error_uri: new URL(url).pathname,
91
- };
92
- return [3, 5];
93
- case 5:
94
- if (responseError) {
95
- throw responseError;
96
- }
97
- else {
98
- return [2, result];
99
- }
100
- return [2];
101
- }
54
+ export var defaultRequest = function (url, options) {
55
+ return __awaiter(this, void 0, void 0, function () {
56
+ var result, responseError, copyOptions, responseResult, jsonResponse, error_1;
57
+ return __generator(this, function (_a) {
58
+ switch (_a.label) {
59
+ case 0:
60
+ result = null;
61
+ responseError = null;
62
+ _a.label = 1;
63
+ case 1:
64
+ _a.trys.push([1, 4, , 5]);
65
+ copyOptions = Object.assign({}, options);
66
+ if (!copyOptions.method) {
67
+ copyOptions.method = 'GET';
68
+ }
69
+ if (copyOptions.body && typeof copyOptions.body !== 'string') {
70
+ copyOptions.body = JSON.stringify(copyOptions.body);
71
+ }
72
+ return [4, fetch(url, copyOptions)];
73
+ case 2:
74
+ responseResult = _a.sent();
75
+ return [4, responseResult.json()];
76
+ case 3:
77
+ jsonResponse = _a.sent();
78
+ if (jsonResponse === null || jsonResponse === void 0 ? void 0 : jsonResponse.error) {
79
+ responseError = jsonResponse;
80
+ responseError.error_uri = new URL(url).pathname;
81
+ }
82
+ else {
83
+ result = jsonResponse;
84
+ }
85
+ return [3, 5];
86
+ case 4:
87
+ error_1 = _a.sent();
88
+ responseError = {
89
+ error: ErrorType.UNREACHABLE,
90
+ error_description: error_1.message,
91
+ error_uri: new URL(url).pathname,
92
+ };
93
+ return [3, 5];
94
+ case 5:
95
+ if (responseError) {
96
+ throw responseError;
97
+ }
98
+ else {
99
+ return [2, result];
100
+ }
101
+ return [2];
102
+ }
103
+ });
102
104
  });
103
- }); };
105
+ };
104
106
  export var toResponseError = function (error, options) {
105
107
  var responseError;
106
108
  var formatOptions = options || {};
@@ -173,11 +175,28 @@ function isCredentialsExpired(credentials) {
173
175
  }
174
176
  var LocalCredentials = (function () {
175
177
  function LocalCredentials(options) {
176
- this._credentials = null;
177
- this._singlePromise = new SinglePromise();
178
- this._tokenSectionName = options.tokenSectionName;
179
- this._storage = options.storage;
178
+ this.credentials = null;
179
+ this.singlePromise = new SinglePromise();
180
+ this.tokenSectionName = options.tokenSectionName;
181
+ this.storage = options.storage;
180
182
  }
183
+ LocalCredentials.prototype.getStorageCredentialsSync = function () {
184
+ var credentials = null;
185
+ var tokenStr = this.storage.getItemSync(this.tokenSectionName);
186
+ if (tokenStr !== undefined && tokenStr !== null) {
187
+ try {
188
+ credentials = JSON.parse(tokenStr);
189
+ if (credentials === null || credentials === void 0 ? void 0 : credentials.expires_at) {
190
+ credentials.expires_at = new Date(credentials.expires_at);
191
+ }
192
+ }
193
+ catch (error) {
194
+ this.storage.removeItem(this.tokenSectionName);
195
+ credentials = null;
196
+ }
197
+ }
198
+ return credentials;
199
+ };
181
200
  LocalCredentials.prototype.setCredentials = function (credentials) {
182
201
  return __awaiter(this, void 0, void 0, function () {
183
202
  var tokenStr;
@@ -186,23 +205,23 @@ var LocalCredentials = (function () {
186
205
  case 0:
187
206
  if (!(credentials === null || credentials === void 0 ? void 0 : credentials.expires_in)) return [3, 3];
188
207
  credentials.expires_at = new Date(Date.now() + (credentials.expires_in - 30) * 1000);
189
- if (!this._storage) return [3, 2];
208
+ if (!this.storage) return [3, 2];
190
209
  tokenStr = JSON.stringify(credentials);
191
- return [4, this._storage.setItem(this._tokenSectionName, tokenStr)];
210
+ return [4, this.storage.setItem(this.tokenSectionName, tokenStr)];
192
211
  case 1:
193
212
  _a.sent();
194
213
  _a.label = 2;
195
214
  case 2:
196
- this._credentials = credentials;
215
+ this.credentials = credentials;
197
216
  return [3, 6];
198
217
  case 3:
199
- if (!this._storage) return [3, 5];
200
- return [4, this._storage.removeItem(this._tokenSectionName)];
218
+ if (!this.storage) return [3, 5];
219
+ return [4, this.storage.removeItem(this.tokenSectionName)];
201
220
  case 4:
202
221
  _a.sent();
203
222
  _a.label = 5;
204
223
  case 5:
205
- this._credentials = null;
224
+ this.credentials = null;
206
225
  _a.label = 6;
207
226
  case 6: return [2];
208
227
  }
@@ -213,35 +232,35 @@ var LocalCredentials = (function () {
213
232
  return __awaiter(this, void 0, void 0, function () {
214
233
  var _this = this;
215
234
  return __generator(this, function (_a) {
216
- return [2, this._singlePromise.run('getCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
235
+ return [2, this.singlePromise.run('getCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
217
236
  var _a;
218
237
  return __generator(this, function (_b) {
219
238
  switch (_b.label) {
220
239
  case 0:
221
- if (!isCredentialsExpired(this._credentials)) return [3, 2];
240
+ if (!isCredentialsExpired(this.credentials)) return [3, 2];
222
241
  _a = this;
223
- return [4, this._getStorageCredentials()];
242
+ return [4, this.getStorageCredentials()];
224
243
  case 1:
225
- _a._credentials = _b.sent();
244
+ _a.credentials = _b.sent();
226
245
  _b.label = 2;
227
- case 2: return [2, this._credentials];
246
+ case 2: return [2, this.credentials];
228
247
  }
229
248
  });
230
249
  }); })];
231
250
  });
232
251
  });
233
252
  };
234
- LocalCredentials.prototype._getStorageCredentials = function () {
253
+ LocalCredentials.prototype.getStorageCredentials = function () {
235
254
  return __awaiter(this, void 0, void 0, function () {
236
255
  var _this = this;
237
256
  return __generator(this, function (_a) {
238
- return [2, this._singlePromise.run('_getStorageCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
257
+ return [2, this.singlePromise.run('_getStorageCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
239
258
  var credentials, tokenStr, error_2;
240
259
  return __generator(this, function (_a) {
241
260
  switch (_a.label) {
242
261
  case 0:
243
262
  credentials = null;
244
- return [4, this._storage.getItem(this._tokenSectionName)];
263
+ return [4, this.storage.getItem(this.tokenSectionName)];
245
264
  case 1:
246
265
  tokenStr = _a.sent();
247
266
  if (!(tokenStr !== undefined && tokenStr !== null)) return [3, 5];
@@ -255,7 +274,7 @@ var LocalCredentials = (function () {
255
274
  return [3, 5];
256
275
  case 3:
257
276
  error_2 = _a.sent();
258
- return [4, this._storage.removeItem(this._tokenSectionName)];
277
+ return [4, this.storage.removeItem(this.tokenSectionName)];
259
278
  case 4:
260
279
  _a.sent();
261
280
  credentials = null;
@@ -267,64 +286,47 @@ var LocalCredentials = (function () {
267
286
  });
268
287
  });
269
288
  };
270
- LocalCredentials.prototype._getStorageCredentialsSync = function () {
271
- var credentials = null;
272
- var tokenStr = this._storage.getItemSync(this._tokenSectionName);
273
- if (tokenStr !== undefined && tokenStr !== null) {
274
- try {
275
- credentials = JSON.parse(tokenStr);
276
- if (credentials === null || credentials === void 0 ? void 0 : credentials.expires_at) {
277
- credentials.expires_at = new Date(credentials.expires_at);
278
- }
279
- }
280
- catch (error) {
281
- this._storage.removeItem(this._tokenSectionName);
282
- credentials = null;
283
- }
284
- }
285
- return credentials;
286
- };
287
289
  return LocalCredentials;
288
290
  }());
289
291
  export { LocalCredentials };
290
292
  var OAuth2Client = (function () {
291
293
  function OAuth2Client(options) {
292
- this._singlePromise = new SinglePromise();
293
- this._apiOrigin = options.apiOrigin;
294
- this._clientId = options.clientId;
295
- this._retry = this._formatRetry(options.retry, OAuth2Client._defaultRetry);
296
- if (options.baseRequest != undefined) {
297
- this._baseRequest = options.baseRequest;
294
+ this.singlePromise = new SinglePromise();
295
+ this.apiOrigin = options.apiOrigin;
296
+ this.clientId = options.clientId;
297
+ this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry);
298
+ if (options.baseRequest) {
299
+ this.baseRequest = options.baseRequest;
298
300
  }
299
301
  else {
300
- this._baseRequest = defaultRequest;
302
+ this.baseRequest = defaultRequest;
301
303
  }
302
- this._tokenInURL = options.tokenInURL;
303
- this._headers = options.headers;
304
- this._storage = options.storage || defaultStorage;
305
- this._localCredentials = new LocalCredentials({
306
- tokenSectionName: 'credentials_' + options.clientId,
307
- storage: this._storage,
304
+ this.tokenInURL = options.tokenInURL;
305
+ this.headers = options.headers;
306
+ this.storage = options.storage || defaultStorage;
307
+ this.localCredentials = new LocalCredentials({
308
+ tokenSectionName: "credentials_" + options.clientId,
309
+ storage: this.storage,
308
310
  });
309
- this._clientSecret = options.clientSecret;
310
- this._refreshTokenFunc =
311
- options.refreshTokenFunc || this._defaultRefreshTokenFunc;
311
+ this.clientSecret = options.clientSecret;
312
+ this.refreshTokenFunc = options.refreshTokenFunc || this.defaultRefreshTokenFunc;
312
313
  }
313
314
  OAuth2Client.prototype.setCredentials = function (credentials) {
314
- return this._localCredentials.setCredentials(credentials);
315
+ return this.localCredentials.setCredentials(credentials);
315
316
  };
316
317
  OAuth2Client.prototype.getAccessToken = function () {
317
318
  return __awaiter(this, void 0, void 0, function () {
318
- var credentials;
319
+ var credentials, respErr;
319
320
  return __generator(this, function (_a) {
320
321
  switch (_a.label) {
321
- case 0: return [4, this._getCredentials()];
322
+ case 0: return [4, this.getCredentials()];
322
323
  case 1:
323
324
  credentials = _a.sent();
324
325
  if (credentials === null || credentials === void 0 ? void 0 : credentials.access_token) {
325
326
  return [2, Promise.resolve(credentials.access_token)];
326
327
  }
327
- return [2, Promise.reject({ error: ErrorType.UNAUTHENTICATED })];
328
+ respErr = { error: ErrorType.UNAUTHENTICATED };
329
+ return [2, Promise.reject(respErr)];
328
330
  }
329
331
  });
330
332
  });
@@ -338,47 +340,46 @@ var OAuth2Client = (function () {
338
340
  if (!options) {
339
341
  options = {};
340
342
  }
341
- retry = this._formatRetry(options.retry, this._retry);
343
+ retry = this.formatRetry(options.retry, this.retry);
342
344
  options.headers = options.headers || {};
343
- if (this._headers) {
344
- options.headers = __assign(__assign({}, this._headers), options.headers);
345
+ if (this.headers) {
346
+ options.headers = __assign(__assign({}, this.headers), options.headers);
345
347
  }
346
348
  if (!options.headers[RequestIdHeaderName]) {
347
349
  options.headers[RequestIdHeaderName] = generateRequestId();
348
350
  }
349
351
  if (!!options.headers[DeviceIdHeaderName]) return [3, 2];
350
- return [4, this._getDeviceId()];
352
+ return [4, this.getDeviceId()];
351
353
  case 1:
352
354
  deviceId = _a.sent();
353
355
  options.headers[DeviceIdHeaderName] = deviceId;
354
356
  _a.label = 2;
355
357
  case 2:
356
358
  if (!(options === null || options === void 0 ? void 0 : options.withCredentials)) return [3, 4];
357
- return [4, this._getCredentials()];
359
+ return [4, this.getCredentials()];
358
360
  case 3:
359
361
  credentials = _a.sent();
360
362
  if (credentials) {
361
- if (this._tokenInURL) {
363
+ if (this.tokenInURL) {
362
364
  if (url.indexOf('?') < 0) {
363
365
  url += '?';
364
366
  }
365
- url += 'access_token=' + credentials.access_token;
367
+ url += "access_token=" + credentials.access_token;
366
368
  }
367
369
  else {
368
- options.headers['Authorization'] =
369
- credentials.token_type + ' ' + credentials.access_token;
370
+ options.headers.Authorization = credentials.token_type + " " + credentials.access_token;
370
371
  }
371
372
  }
372
373
  return [3, 5];
373
374
  case 4:
374
- if (this._clientId && url.indexOf('client_id') < 0) {
375
+ if (this.clientId && url.indexOf('client_id') < 0) {
375
376
  url += url.indexOf('?') < 0 ? '?' : '&';
376
- url += 'client_id=' + this._clientId;
377
+ url += "client_id=" + this.clientId;
377
378
  }
378
379
  _a.label = 5;
379
380
  case 5:
380
381
  if (url.startsWith('/')) {
381
- url = this._apiOrigin + url;
382
+ url = this.apiOrigin + url;
382
383
  }
383
384
  response = null;
384
385
  maxRequestTimes = retry + 1;
@@ -389,7 +390,7 @@ var OAuth2Client = (function () {
389
390
  _a.label = 7;
390
391
  case 7:
391
392
  _a.trys.push([7, 9, , 12]);
392
- return [4, this._baseRequest(url, options)];
393
+ return [4, this.baseRequest(url, options)];
393
394
  case 8:
394
395
  response = _a.sent();
395
396
  return [3, 15];
@@ -401,13 +402,13 @@ var OAuth2Client = (function () {
401
402
  _a.sent();
402
403
  return [2, Promise.reject(responseError_1)];
403
404
  case 11:
404
- if (requestTime === retry ||
405
- !responseError_1 ||
406
- responseError_1.error !== 'unreachable') {
405
+ if (requestTime === retry
406
+ || !responseError_1
407
+ || responseError_1.error !== 'unreachable') {
407
408
  return [2, Promise.reject(responseError_1)];
408
409
  }
409
410
  return [3, 12];
410
- case 12: return [4, this._sleep(OAuth2Client._retryInterval)];
411
+ case 12: return [4, this.sleep(OAuth2Client.retryInterval)];
411
412
  case 13:
412
413
  _a.sent();
413
414
  _a.label = 14;
@@ -419,11 +420,73 @@ var OAuth2Client = (function () {
419
420
  });
420
421
  });
421
422
  };
422
- OAuth2Client.prototype._checkRetry = function (retry) {
423
+ OAuth2Client.prototype.getCredentials = function () {
424
+ return __awaiter(this, void 0, void 0, function () {
425
+ var credentials;
426
+ return __generator(this, function (_a) {
427
+ switch (_a.label) {
428
+ case 0: return [4, this.localCredentials.getCredentials()];
429
+ case 1:
430
+ credentials = _a.sent();
431
+ if (!isCredentialsExpired(credentials)) return [3, 5];
432
+ if (!(credentials && credentials.scope === 'anonymous')) return [3, 3];
433
+ return [4, this.anonymousSignIn(credentials)];
434
+ case 2:
435
+ credentials = _a.sent();
436
+ return [3, 5];
437
+ case 3: return [4, this.refreshToken(credentials)];
438
+ case 4:
439
+ credentials = _a.sent();
440
+ _a.label = 5;
441
+ case 5: return [2, credentials];
442
+ }
443
+ });
444
+ });
445
+ };
446
+ OAuth2Client.prototype.getCredentialsSync = function () {
447
+ var credentials = this.localCredentials.getStorageCredentialsSync();
448
+ return credentials;
449
+ };
450
+ OAuth2Client.prototype.getCredentialsAsync = function () {
451
+ return this.localCredentials.getCredentials();
452
+ };
453
+ OAuth2Client.prototype.getScope = function () {
454
+ return __awaiter(this, void 0, void 0, function () {
455
+ var credentials;
456
+ return __generator(this, function (_a) {
457
+ switch (_a.label) {
458
+ case 0: return [4, this.localCredentials.getCredentials()];
459
+ case 1:
460
+ credentials = _a.sent();
461
+ if (!credentials) {
462
+ return [2, this.unAuthenticatedError('credentials not found')];
463
+ }
464
+ return [2, credentials.scope];
465
+ }
466
+ });
467
+ });
468
+ };
469
+ OAuth2Client.prototype.getGroups = function () {
470
+ return __awaiter(this, void 0, void 0, function () {
471
+ var credentials;
472
+ return __generator(this, function (_a) {
473
+ switch (_a.label) {
474
+ case 0: return [4, this.localCredentials.getCredentials()];
475
+ case 1:
476
+ credentials = _a.sent();
477
+ if (!credentials) {
478
+ return [2, this.unAuthenticatedError('credentials not found')];
479
+ }
480
+ return [2, credentials.groups];
481
+ }
482
+ });
483
+ });
484
+ };
485
+ OAuth2Client.prototype.checkRetry = function (retry) {
423
486
  var responseError = null;
424
- if (typeof retry !== 'number' ||
425
- retry < OAuth2Client._minRetry ||
426
- retry > OAuth2Client._maxRetry) {
487
+ if (typeof retry !== 'number'
488
+ || retry < OAuth2Client.minRetry
489
+ || retry > OAuth2Client.maxRetry) {
427
490
  responseError = {
428
491
  error: ErrorType.UNREACHABLE,
429
492
  error_description: 'wrong options param: retry',
@@ -434,15 +497,13 @@ var OAuth2Client = (function () {
434
497
  }
435
498
  return retry;
436
499
  };
437
- OAuth2Client.prototype._formatRetry = function (retry, defaultVale) {
500
+ OAuth2Client.prototype.formatRetry = function (retry, defaultVale) {
438
501
  if (typeof retry === 'undefined') {
439
502
  return defaultVale;
440
503
  }
441
- else {
442
- return this._checkRetry(retry);
443
- }
504
+ return this.checkRetry(retry);
444
505
  };
445
- OAuth2Client.prototype._sleep = function (ms) {
506
+ OAuth2Client.prototype.sleep = function (ms) {
446
507
  return __awaiter(this, void 0, void 0, function () {
447
508
  return __generator(this, function (_a) {
448
509
  return [2, new Promise(function (resolve) {
@@ -453,35 +514,35 @@ var OAuth2Client = (function () {
453
514
  });
454
515
  });
455
516
  };
456
- OAuth2Client.prototype._refreshToken = function (credentials) {
517
+ OAuth2Client.prototype.refreshToken = function (credentials) {
457
518
  return __awaiter(this, void 0, void 0, function () {
458
519
  var _this = this;
459
520
  return __generator(this, function (_a) {
460
- return [2, this._singlePromise.run('_refreshToken', function () { return __awaiter(_this, void 0, void 0, function () {
521
+ return [2, this.singlePromise.run('_refreshToken', function () { return __awaiter(_this, void 0, void 0, function () {
461
522
  var newCredentials, error_3;
462
523
  return __generator(this, function (_a) {
463
524
  switch (_a.label) {
464
525
  case 0:
465
526
  if (!credentials || !credentials.refresh_token) {
466
- return [2, this._unAuthenticatedError('no refresh token found in credentials')];
527
+ return [2, this.unAuthenticatedError('no refresh token found in credentials')];
467
528
  }
468
529
  _a.label = 1;
469
530
  case 1:
470
531
  _a.trys.push([1, 4, , 7]);
471
- return [4, this._refreshTokenFunc(credentials.refresh_token)];
532
+ return [4, this.refreshTokenFunc(credentials.refresh_token)];
472
533
  case 2:
473
534
  newCredentials = _a.sent();
474
- return [4, this._localCredentials.setCredentials(newCredentials)];
535
+ return [4, this.localCredentials.setCredentials(newCredentials)];
475
536
  case 3:
476
537
  _a.sent();
477
538
  return [2, newCredentials];
478
539
  case 4:
479
540
  error_3 = _a.sent();
480
541
  if (!(error_3.error === ErrorType.INVALID_GRANT)) return [3, 6];
481
- return [4, this._localCredentials.setCredentials(null)];
542
+ return [4, this.localCredentials.setCredentials(null)];
482
543
  case 5:
483
544
  _a.sent();
484
- return [2, this._unAuthenticatedError(error_3.error_description)];
545
+ return [2, this.unAuthenticatedError(error_3.error_description)];
485
546
  case 6: return [2, Promise.reject(error_3)];
486
547
  case 7: return [2];
487
548
  }
@@ -490,17 +551,17 @@ var OAuth2Client = (function () {
490
551
  });
491
552
  });
492
553
  };
493
- OAuth2Client.prototype._anonymousSignIn = function (credentials) {
554
+ OAuth2Client.prototype.anonymousSignIn = function (credentials) {
494
555
  return __awaiter(this, void 0, void 0, function () {
495
556
  var _this = this;
496
557
  return __generator(this, function (_a) {
497
- return [2, this._singlePromise.run('_anonymous', function () { return __awaiter(_this, void 0, void 0, function () {
558
+ return [2, this.singlePromise.run('_anonymous', function () { return __awaiter(_this, void 0, void 0, function () {
498
559
  var newCredentials, error_4;
499
560
  return __generator(this, function (_a) {
500
561
  switch (_a.label) {
501
562
  case 0:
502
563
  if (!credentials || credentials.scope !== 'anonymous') {
503
- return [2, this._unAuthenticatedError('no anonymous in credentials')];
564
+ return [2, this.unAuthenticatedError('no anonymous in credentials')];
504
565
  }
505
566
  _a.label = 1;
506
567
  case 1:
@@ -508,23 +569,23 @@ var OAuth2Client = (function () {
508
569
  return [4, this.request('/auth/v1/signin/anonymously', {
509
570
  method: 'POST',
510
571
  body: {
511
- client_id: this._clientId,
512
- client_secret: this._clientSecret,
572
+ client_id: this.clientId,
573
+ client_secret: this.clientSecret,
513
574
  },
514
575
  })];
515
576
  case 2:
516
577
  newCredentials = _a.sent();
517
- return [4, this._localCredentials.setCredentials(newCredentials)];
578
+ return [4, this.localCredentials.setCredentials(newCredentials)];
518
579
  case 3:
519
580
  _a.sent();
520
581
  return [2, newCredentials];
521
582
  case 4:
522
583
  error_4 = _a.sent();
523
584
  if (!(error_4.error === ErrorType.INVALID_GRANT)) return [3, 6];
524
- return [4, this._localCredentials.setCredentials(null)];
585
+ return [4, this.localCredentials.setCredentials(null)];
525
586
  case 5:
526
587
  _a.sent();
527
- return [2, this._unAuthenticatedError(error_4.error_description)];
588
+ return [2, this.unAuthenticatedError(error_4.error_description)];
528
589
  case 6: return [2, Promise.reject(error_4)];
529
590
  case 7: return [2];
530
591
  }
@@ -533,120 +594,59 @@ var OAuth2Client = (function () {
533
594
  });
534
595
  });
535
596
  };
536
- OAuth2Client.prototype._defaultRefreshTokenFunc = function (refreshToken) {
597
+ OAuth2Client.prototype.defaultRefreshTokenFunc = function (refreshToken) {
537
598
  if (refreshToken === undefined || refreshToken === '') {
538
- return this._unAuthenticatedError('refresh token not found');
599
+ return this.unAuthenticatedError('refresh token not found');
539
600
  }
540
601
  return this.request('/auth/v1/token', {
541
602
  method: 'POST',
542
603
  body: {
543
- client_id: this._clientId,
544
- client_secret: this._clientSecret,
604
+ client_id: this.clientId,
605
+ client_secret: this.clientSecret,
545
606
  grant_type: 'refresh_token',
546
607
  refresh_token: refreshToken,
547
608
  },
548
609
  });
549
610
  };
550
- OAuth2Client.prototype._getCredentials = function () {
551
- return __awaiter(this, void 0, void 0, function () {
552
- var credentials;
553
- return __generator(this, function (_a) {
554
- switch (_a.label) {
555
- case 0: return [4, this._localCredentials.getCredentials()];
556
- case 1:
557
- credentials = _a.sent();
558
- if (!isCredentialsExpired(credentials)) return [3, 5];
559
- if (!(credentials && credentials.scope === 'anonymous')) return [3, 3];
560
- return [4, this._anonymousSignIn(credentials)];
561
- case 2:
562
- credentials = _a.sent();
563
- return [3, 5];
564
- case 3: return [4, this._refreshToken(credentials)];
565
- case 4:
566
- credentials = _a.sent();
567
- _a.label = 5;
568
- case 5: return [2, credentials];
569
- }
570
- });
571
- });
572
- };
573
- OAuth2Client.prototype.getCredentialsSync = function () {
574
- var credentials = this._localCredentials._getStorageCredentialsSync();
575
- return credentials;
576
- };
577
- OAuth2Client.prototype.getCredentialsAsync = function () {
578
- return this._localCredentials.getCredentials();
579
- };
580
- OAuth2Client.prototype.getScope = function () {
581
- return __awaiter(this, void 0, void 0, function () {
582
- var credentials;
583
- return __generator(this, function (_a) {
584
- switch (_a.label) {
585
- case 0: return [4, this._localCredentials.getCredentials()];
586
- case 1:
587
- credentials = _a.sent();
588
- if (credentials == null) {
589
- return [2, this._unAuthenticatedError("credentials not found")];
590
- }
591
- return [2, credentials.scope];
592
- }
593
- });
594
- });
595
- };
596
- OAuth2Client.prototype.getGroups = function () {
597
- return __awaiter(this, void 0, void 0, function () {
598
- var credentials;
599
- return __generator(this, function (_a) {
600
- switch (_a.label) {
601
- case 0: return [4, this._localCredentials.getCredentials()];
602
- case 1:
603
- credentials = _a.sent();
604
- if (credentials == null) {
605
- return [2, this._unAuthenticatedError("credentials not found")];
606
- }
607
- return [2, credentials.groups];
608
- }
609
- });
610
- });
611
- };
612
- OAuth2Client.prototype._getDeviceId = function () {
611
+ OAuth2Client.prototype.getDeviceId = function () {
613
612
  return __awaiter(this, void 0, void 0, function () {
614
613
  var deviceId;
615
614
  return __generator(this, function (_a) {
616
615
  switch (_a.label) {
617
616
  case 0:
618
- if (this._deviceID) {
619
- return [2, this._deviceID];
617
+ if (this.deviceID) {
618
+ return [2, this.deviceID];
620
619
  }
621
- return [4, this._storage.getItem(DeviceIdSectionName)];
620
+ return [4, this.storage.getItem(DeviceIdSectionName)];
622
621
  case 1:
623
622
  deviceId = _a.sent();
624
- if (!!(typeof deviceId === 'string' &&
625
- deviceId.length >= 16 &&
626
- deviceId.length <= 48)) return [3, 3];
623
+ if (!!(typeof deviceId === 'string'
624
+ && deviceId.length >= 16
625
+ && deviceId.length <= 48)) return [3, 3];
627
626
  deviceId = uuidv4();
628
- return [4, this._storage.setItem(DeviceIdSectionName, deviceId)];
627
+ return [4, this.storage.setItem(DeviceIdSectionName, deviceId)];
629
628
  case 2:
630
629
  _a.sent();
631
630
  _a.label = 3;
632
631
  case 3:
633
- this._deviceID = deviceId;
632
+ this.deviceID = deviceId;
634
633
  return [2, deviceId];
635
634
  }
636
635
  });
637
636
  });
638
637
  };
639
- OAuth2Client.prototype._unAuthenticatedError = function (err) {
640
- return Promise.reject({
638
+ OAuth2Client.prototype.unAuthenticatedError = function (err) {
639
+ var respErr = {
641
640
  error: ErrorType.UNAUTHENTICATED,
642
641
  error_description: err,
643
- });
642
+ };
643
+ return Promise.reject(respErr);
644
644
  };
645
- OAuth2Client._defaultRetry = 2;
646
- OAuth2Client._minRetry = 0;
647
- OAuth2Client._maxRetry = 5;
648
- OAuth2Client._retryInterval = 1000;
645
+ OAuth2Client.defaultRetry = 2;
646
+ OAuth2Client.minRetry = 0;
647
+ OAuth2Client.maxRetry = 5;
648
+ OAuth2Client.retryInterval = 1000;
649
649
  return OAuth2Client;
650
650
  }());
651
651
  export { OAuth2Client };
652
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2client.js","sourceRoot":"","sources":["../../../src/oauth2client/oauth2client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrorType } from './consts';\n\nimport { AuthClient, SimpleStorage } from './interface';\n\nimport {\n  Credentials,\n  ResponseError,\n  RequestOptions,\n  RequestFunction,\n  OAuth2ClientOptions,\n  AuthClientRequestOptions,\n} from './models';\n\nimport { uuidv4 } from '../utils/uuid';\n\nimport { SinglePromise } from '../utils/function/single-promise';\n\nconst RequestIdHeaderName = 'x-request-id';\nconst DeviceIdHeaderName = 'x-device-id';\nconst DeviceIdSectionName = 'device_id';\n\nexport interface ToResponseErrorOptions {\n  error?: ErrorType;\n  error_description?: string | null;\n  error_uri?: string | null;\n  details?: any | null;\n}\n\nexport const defaultRequest: RequestFunction = async <T>(\n  url: string,\n  options?: RequestOptions,\n): Promise<T> => {\n  let result: T | null = null;\n  let responseError: ResponseError | null = null;\n  try {\n    // Objects must be copied to prevent modification of data such as body.\n    const copyOptions = Object.assign({}, options);\n    if (!copyOptions.method) {\n      copyOptions.method = 'GET';\n    }\n    if (copyOptions.body && typeof copyOptions.body !== 'string') {\n      copyOptions.body = JSON.stringify(copyOptions.body);\n    }\n    const responseResult: Response = await fetch(url, copyOptions);\n    const jsonResponse = await responseResult.json();\n    if (jsonResponse?.error) {\n      responseError = jsonResponse as ResponseError;\n      responseError.error_uri = new URL(url).pathname;\n    } else {\n      result = jsonResponse as T;\n    }\n  } catch (error) {\n    responseError = {\n      error: ErrorType.UNREACHABLE,\n      error_description: error.message,\n      error_uri: new URL(url).pathname,\n    };\n  }\n  if (responseError) {\n    throw responseError;\n  } else {\n    return result;\n  }\n};\n\nexport const toResponseError = (\n  error: ResponseError | Error,\n  options?: ToResponseErrorOptions,\n): ResponseError => {\n  let responseError: ResponseError;\n  const formatOptions: ToResponseErrorOptions = options || {};\n  if (error instanceof Error) {\n    responseError = {\n      error: formatOptions.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || error.message,\n      error_uri: formatOptions.error_uri,\n      details: formatOptions.details || error.stack,\n    };\n  } else {\n    const formatError: ToResponseErrorOptions = error || {};\n    responseError = {\n      error: formatOptions.error || formatError.error || ErrorType.LOCAL,\n      error_description:\n        formatOptions.error_description || formatError.error_description,\n      error_uri: formatOptions.error_uri || formatError.error_uri,\n      details: formatOptions.details || formatError.details,\n    };\n  }\n  return responseError;\n};\n\n/**\n * Generate request id.\n * @return {string}\n */\nexport function generateRequestId(): string {\n  return uuidv4();\n}\n\n\n/**\n * Default Storage.\n */\nclass DefaultStorage implements SimpleStorage {\n  /**\n     * Get item.\n     * @param {string} key\n     */\n  async getItem(key: string): Promise<string | null> {\n    return window.localStorage.getItem(key);\n  }\n\n  /**\n     * Remove item.\n     * @param {string} key\n     */\n  async removeItem(key: string): Promise<void> {\n    window.localStorage.removeItem(key);\n  }\n\n  /**\n     * Set item.\n     * @param {string} key\n     * @param {string} value\n     */\n  async setItem(key: string, value: string): Promise<void> {\n    window.localStorage.setItem(key, value);\n  }\n\n  /**\n     * Get item sync.\n     * @param {string} key\n     */\n  getItemSync(key: string): string | null {\n    return window.localStorage.getItem(key);\n  }\n\n  /**\n     * Remove item sync.\n     * @param {string} key\n     */\n  removeItemSync(key: string): void {\n    window.localStorage.removeItem(key);\n  }\n\n  /**\n     * Set item sync.\n     * @param {string} key\n     * @param {string} value\n     */\n  setItemSync(key: string, value: string): void {\n    window.localStorage.setItem(key, value);\n  }\n}\n\nexport const defaultStorage = new DefaultStorage();\n\ninterface LocalCredentialsOptions {\n  tokenSectionName: string;\n  storage: SimpleStorage;\n}\n\n/**\n * Check if credentials is expired.\n * @param {Credentials} credentials\n * @return {boolean}\n */\nfunction isCredentialsExpired(credentials: Credentials): boolean {\n  let isExpired = true;\n  if (credentials?.expires_at && credentials?.access_token) {\n    isExpired = credentials.expires_at < new Date();\n  }\n  return isExpired;\n}\n\n/**\n * Local credentials.\n * Local credentials, with memory cache and storage cache.\n * If the memory cache expires, the storage cache is automatically loaded.\n */\nexport class LocalCredentials {\n  private _tokenSectionName: string;\n\n  private _storage: SimpleStorage;\n\n  private _credentials: Credentials | null = null;\n\n  private _singlePromise: SinglePromise = new SinglePromise();\n\n  /**\n   * constructor\n   * @param {LocalCredentialsOptions} options\n   */\n  constructor(options: LocalCredentialsOptions) {\n    this._tokenSectionName = options.tokenSectionName;\n    this._storage = options.storage;\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   */\n  public async setCredentials(credentials?: Credentials): Promise<void> {\n    if (credentials?.expires_in) {\n      credentials.expires_at = new Date(\n        Date.now() + (credentials.expires_in - 30) * 1000,\n      );\n      if (this._storage) {\n        const tokenStr: string = JSON.stringify(credentials);\n        await this._storage.setItem(this._tokenSectionName, tokenStr);\n      }\n      this._credentials = credentials;\n    } else {\n      if (this._storage) {\n        await this._storage.removeItem(this._tokenSectionName);\n      }\n      this._credentials = null;\n    }\n  }\n\n  /**\n   * Get credentials.\n   * @return {Promise<Credentials | null>}\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    return this._singlePromise.run('getCredentials', async () => {\n      if (isCredentialsExpired(this._credentials)) {\n        this._credentials = await this._getStorageCredentials();\n      }\n      return this._credentials;\n    });\n  }\n\n  /**\n   * Get storage credentials.\n   */\n  private async _getStorageCredentials(): Promise<Credentials | null> {\n    return this._singlePromise.run('_getStorageCredentials', async () => {\n      let credentials: Credentials = null;\n      const tokenStr: string = await this._storage.getItem(\n        this._tokenSectionName,\n      );\n      if (tokenStr !== undefined && tokenStr !== null) {\n        try {\n          credentials = JSON.parse(tokenStr);\n          if (credentials?.expires_at) {\n            credentials.expires_at = new Date(credentials.expires_at);\n          }\n        } catch (error) {\n          await this._storage.removeItem(this._tokenSectionName);\n          credentials = null;\n        }\n      }\n      return credentials;\n    });\n  }\n\n  public _getStorageCredentialsSync(): Credentials | null {\n    let credentials: Credentials = null;\n    const tokenStr: string = this._storage.getItemSync(\n      this._tokenSectionName,\n    );\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        credentials = JSON.parse(tokenStr);\n        if (credentials?.expires_at) {\n          credentials.expires_at = new Date(credentials.expires_at);\n        }\n      } catch (error) {\n        this._storage.removeItem(this._tokenSectionName);\n        credentials = null;\n      }\n    }\n    return credentials\n  }\n\n}\n\n/**\n * OAuth2Client\n */\nexport class OAuth2Client implements AuthClient {\n  private static _defaultRetry = 2;\n  private static _minRetry = 0;\n  private static _maxRetry = 5;\n  private static _retryInterval = 1000;\n\n  private _apiOrigin: string;\n  private _clientId: string;\n  private _retry: number;\n  private _clientSecret?: string;\n  private _baseRequest: <T>(\n    url: string,\n    options?: RequestOptions,\n  ) => Promise<T>;\n  private _localCredentials: LocalCredentials;\n  private _storage: SimpleStorage;\n  private _deviceID?: string;\n  private _tokenInURL?: boolean;\n  private _refreshTokenFunc: (refreshToken?: string) => Promise<Credentials>;\n  private _headers?: { [key: string]: string };\n  private _singlePromise: SinglePromise = new SinglePromise();\n\n  /**\n   * constructor\n   * @param {OAuth2ClientOptions} options\n   */\n  constructor(options: OAuth2ClientOptions) {\n    this._apiOrigin = options.apiOrigin;\n    this._clientId = options.clientId;\n    this._retry = this._formatRetry(options.retry, OAuth2Client._defaultRetry);\n    if (options.baseRequest != undefined) {\n      this._baseRequest = options.baseRequest;\n    } else {\n      this._baseRequest = defaultRequest;\n    }\n    this._tokenInURL = options.tokenInURL;\n    this._headers = options.headers;\n    // @ts-ignore\n    this._storage = options.storage || defaultStorage;\n    this._localCredentials = new LocalCredentials({\n      tokenSectionName: 'credentials_' + options.clientId,\n      storage: this._storage,\n    });\n    this._clientSecret = options.clientSecret;\n    this._refreshTokenFunc =\n      options.refreshTokenFunc || this._defaultRefreshTokenFunc;\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   * @return {Promise<void>}\n   */\n  public setCredentials(credentials?: Credentials): Promise<void> {\n    return this._localCredentials.setCredentials(credentials);\n  }\n\n  /**\n   * getAccessToken return a validate access token\n   */\n  public async getAccessToken(): Promise<string> {\n    const credentials: Credentials = await this._getCredentials();\n    if (credentials?.access_token) {\n      return Promise.resolve(credentials.access_token);\n    }\n    return Promise.reject({ error: ErrorType.UNAUTHENTICATED } as ResponseError);\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(\n    url: string,\n    options?: AuthClientRequestOptions,\n  ): Promise<T> {\n    if (!options) {\n      options = {};\n    }\n    const retry: number = this._formatRetry(options.retry, this._retry);\n    options.headers = options.headers || {};\n    if (this._headers) {\n      options.headers = {\n        ...this._headers,\n        ...options.headers,\n      };\n    }\n    if (!options.headers[RequestIdHeaderName]) {\n      options.headers[RequestIdHeaderName] = generateRequestId();\n    }\n    if (!options.headers[DeviceIdHeaderName]) {\n      const deviceId = await this._getDeviceId();\n      options.headers[DeviceIdHeaderName] = deviceId;\n    }\n    if (options?.withCredentials) {\n      const credentials = await this._getCredentials();\n      if (credentials) {\n        if (this._tokenInURL) {\n          if (url.indexOf('?') < 0) {\n            url += '?';\n          }\n          url += 'access_token=' + credentials.access_token;\n        } else {\n          options.headers['Authorization'] =\n            credentials.token_type + ' ' + credentials.access_token;\n        }\n      }\n    } else {\n      if (this._clientId && url.indexOf('client_id') < 0) {\n        url += url.indexOf('?') < 0 ? '?' : '&';\n        url += 'client_id=' + this._clientId;\n      }\n    }\n    if (url.startsWith('/')) {\n      url = this._apiOrigin + url;\n    }\n    let response: T | null = null;\n    const maxRequestTimes: number = retry + 1;\n    for (\n      let requestTime = 0;\n      requestTime < maxRequestTimes;\n      requestTime++\n    ) {\n      try {\n        response = await this._baseRequest<T>(url, options);\n        break;\n      } catch (responseError) {\n        if (options.withCredentials && responseError && responseError.error === ErrorType.UNAUTHENTICATED) {\n          await this.setCredentials(null);\n          return Promise.reject(responseError);\n        }\n        \n        if (\n          requestTime === retry ||\n          !responseError ||\n          responseError.error !== 'unreachable'\n        ) {\n          return Promise.reject(responseError);\n        }\n      }\n      await this._sleep(OAuth2Client._retryInterval);\n    }\n    return response;\n  }\n\n  /**\n   * Check retry value.\n   * @param {number} retry\n   * @return {number}\n   */\n  private _checkRetry(retry: number): number {\n    let responseError: ResponseError | null = null;\n    if (\n      typeof retry !== 'number' ||\n      retry < OAuth2Client._minRetry ||\n      retry > OAuth2Client._maxRetry\n    ) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: 'wrong options param: retry',\n      };\n    }\n    if (responseError) {\n      throw responseError;\n    }\n    return retry;\n  }\n\n  /**\n   * Format retry value.\n   * @param {number} retry\n   * @param {number} defaultVale\n   * @return {number}\n   */\n  private _formatRetry(retry: number, defaultVale: number): number {\n    if (typeof retry === 'undefined') {\n      return defaultVale;\n    } else {\n      return this._checkRetry(retry);\n    }\n  }\n\n  /**\n   * Sleep.\n   * @param {number} ms\n   * @return {Promise<void>}\n   */\n  private async _sleep(ms: number): Promise<void> {\n    return new Promise<void>((resolve) => {\n      setTimeout(() => {\n        resolve();\n      }, ms);\n    });\n  }\n\n  /**\n   * Refresh expired token.\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async _refreshToken(credentials: Credentials): Promise<Credentials> {\n    return this._singlePromise.run('_refreshToken', async () => {\n      if (!credentials || !credentials.refresh_token) {\n        return this._unAuthenticatedError('no refresh token found in credentials');\n      }\n      try {\n        const newCredentials: Credentials = await this._refreshTokenFunc(\n          credentials.refresh_token,\n        );\n        await this._localCredentials.setCredentials(newCredentials);\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this._localCredentials.setCredentials(null);\n          return this._unAuthenticatedError(error.error_description);\n        }\n        return Promise.reject(error);\n      }\n    });\n  }\n\n  /**\n   * anonymous signIn\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async _anonymousSignIn(credentials: Credentials): Promise<Credentials> {\n    return this._singlePromise.run('_anonymous', async () => {\n      if (!credentials || credentials.scope !== 'anonymous') {\n        return this._unAuthenticatedError('no anonymous in credentials');\n      }\n      try {\n        const newCredentials: Credentials = await this.request('/auth/v1/signin/anonymously', {\n          method: 'POST',\n          body: {\n            client_id: this._clientId,\n            client_secret: this._clientSecret,\n          },\n        });\n        await this._localCredentials.setCredentials(newCredentials);\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this._localCredentials.setCredentials(null);\n          return this._unAuthenticatedError(error.error_description);\n        }\n        return Promise.reject(error);\n      }\n    });\n  }\n\n  /**\n   * Default refresh token function.\n   * @param {string} refreshToken\n   * @return {Promise<Credentials>}\n   */\n  private _defaultRefreshTokenFunc(\n    refreshToken?: string,\n  ): Promise<Credentials> {\n    if (refreshToken === undefined || refreshToken === '') {\n      return this._unAuthenticatedError('refresh token not found');\n    }\n    return this.request('/auth/v1/token', {\n      method: 'POST',\n      body: {\n        client_id: this._clientId,\n        client_secret: this._clientSecret,\n        grant_type: 'refresh_token',\n        refresh_token: refreshToken,\n      },\n    });\n  }\n\n  /**\n   * Get credentials.\n   */\n  public async _getCredentials(): Promise<Credentials | null> {\n    let credentials: Credentials = await this._localCredentials.getCredentials();\n    if (isCredentialsExpired(credentials)) {\n      if (credentials && credentials.scope === 'anonymous') {\n        credentials = await this._anonymousSignIn(credentials)\n      } else {\n        credentials = await this._refreshToken(credentials);\n      }\n    }\n    return credentials;\n  }\n\n  public getCredentialsSync(): Credentials | null {\n    const credentials: Credentials = this._localCredentials._getStorageCredentialsSync();\n    return credentials\n  }\n\n  public getCredentialsAsync(): Promise<Credentials | null> {\n    return this._localCredentials.getCredentials()\n  }\n\n  public async getScope(): Promise<string> {\n    let credentials: Credentials = await this._localCredentials.getCredentials();\n    if (credentials == null) {\n      return this._unAuthenticatedError(\"credentials not found\")\n    }\n    return credentials.scope;\n  }\n\n  public async getGroups(): Promise<string[]> {\n    let credentials: Credentials = await this._localCredentials.getCredentials();\n    if (credentials == null) {\n      return this._unAuthenticatedError(\"credentials not found\")\n    }\n    return credentials.groups;\n  }\n\n\n  /**\n   * Get deviceId\n   */\n  private async _getDeviceId(): Promise<string> {\n    if (this._deviceID) {\n      return this._deviceID;\n    }\n    let deviceId: string = await this._storage.getItem(\n      DeviceIdSectionName,\n    );\n    if (!(typeof deviceId === 'string' &&\n      deviceId.length >= 16 &&\n      deviceId.length <= 48)) {\n      deviceId = uuidv4();\n      await this._storage.setItem(DeviceIdSectionName, deviceId);\n    }\n    this._deviceID = deviceId;\n    return deviceId;\n  }\n  /**\n   * Generate unAuthenticated error.\n   * @param {string} err\n   * @return {Promise<T>}\n   */\n  private _unAuthenticatedError<T>(err?: string): Promise<T> {\n    return Promise.reject({\n      error: ErrorType.UNAUTHENTICATED,\n      error_description: err,\n    } as ResponseError);\n  }\n}\n"]}
652
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2client.js","sourceRoot":"","sources":["../../../src/oauth2client/oauth2client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrorType } from './consts'\n\nimport { AuthClient, SimpleStorage } from './interface'\n\nimport {\n  Credentials,\n  ResponseError,\n  RequestOptions,\n  RequestFunction,\n  OAuth2ClientOptions,\n  AuthClientRequestOptions,\n} from './models'\n\nimport { uuidv4 } from '../utils/uuid'\n\nimport { SinglePromise } from '../utils/function/single-promise'\n\nconst RequestIdHeaderName = 'x-request-id'\nconst DeviceIdHeaderName = 'x-device-id'\nconst DeviceIdSectionName = 'device_id'\n\nexport interface ToResponseErrorOptions {\n  error?: ErrorType;\n  error_description?: string | null;\n  error_uri?: string | null;\n  details?: any | null;\n}\n\n\nexport const defaultRequest: RequestFunction = async function <T>(\n  url: string,\n  options?: RequestOptions\n): Promise<T> {\n  let result: T | null = null\n  let responseError: ResponseError | null = null\n  try {\n    // Objects must be copied to prevent modification of data such as body.\n    const copyOptions = Object.assign({}, options)\n    if (!copyOptions.method) {\n      copyOptions.method = 'GET'\n    }\n    if (copyOptions.body && typeof copyOptions.body !== 'string') {\n      copyOptions.body = JSON.stringify(copyOptions.body)\n    }\n    const responseResult: Response = await fetch(url, copyOptions)\n    const jsonResponse = await responseResult.json()\n    if (jsonResponse?.error) {\n      responseError = jsonResponse as ResponseError\n      responseError.error_uri = new URL(url).pathname\n    } else {\n      result = jsonResponse as T\n    }\n  } catch (error) {\n    responseError = {\n      error: ErrorType.UNREACHABLE,\n      error_description: error.message,\n      error_uri: new URL(url).pathname,\n    }\n  }\n  if (responseError) {\n    throw responseError\n  } else {\n    return result\n  }\n}\n\nexport const toResponseError = (\n  error: ResponseError | Error,\n  options?: ToResponseErrorOptions,\n): ResponseError => {\n  let responseError: ResponseError\n  const formatOptions: ToResponseErrorOptions = options || {}\n  if (error instanceof Error) {\n    responseError = {\n      error: formatOptions.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || error.message,\n      error_uri: formatOptions.error_uri,\n      details: formatOptions.details || error.stack,\n    }\n  } else {\n    const formatError: ToResponseErrorOptions = error || {}\n    responseError = {\n      error: formatOptions.error || formatError.error || ErrorType.LOCAL,\n      error_description:\n        formatOptions.error_description || formatError.error_description,\n      error_uri: formatOptions.error_uri || formatError.error_uri,\n      details: formatOptions.details || formatError.details,\n    }\n  }\n  return responseError\n}\n\n/**\n * Generate request id.\n * @return {string}\n */\nexport function generateRequestId(): string {\n  return uuidv4()\n}\n\n\n/**\n * Default Storage.\n */\nclass DefaultStorage implements SimpleStorage {\n  /**\n     * Get item.\n     * @param {string} key\n     */\n  async getItem(key: string): Promise<string | null> {\n    return window.localStorage.getItem(key)\n  }\n\n  /**\n     * Remove item.\n     * @param {string} key\n     */\n  async removeItem(key: string): Promise<void> {\n    window.localStorage.removeItem(key)\n  }\n\n  /**\n     * Set item.\n     * @param {string} key\n     * @param {string} value\n     */\n  async setItem(key: string, value: string): Promise<void> {\n    window.localStorage.setItem(key, value)\n  }\n\n  /**\n     * Get item sync.\n     * @param {string} key\n     */\n  getItemSync(key: string): string | null {\n    return window.localStorage.getItem(key)\n  }\n\n  /**\n     * Remove item sync.\n     * @param {string} key\n     */\n  removeItemSync(key: string): void {\n    window.localStorage.removeItem(key)\n  }\n\n  /**\n     * Set item sync.\n     * @param {string} key\n     * @param {string} value\n     */\n  setItemSync(key: string, value: string): void {\n    window.localStorage.setItem(key, value)\n  }\n}\n\nexport const defaultStorage = new DefaultStorage()\n\ninterface LocalCredentialsOptions {\n  tokenSectionName: string;\n  storage: SimpleStorage;\n}\n\n/**\n * Check if credentials is expired.\n * @param {Credentials} credentials\n * @return {boolean}\n */\nfunction isCredentialsExpired(credentials: Credentials): boolean {\n  let isExpired = true\n  if (credentials?.expires_at && credentials?.access_token) {\n    isExpired = credentials.expires_at < new Date()\n  }\n  return isExpired\n}\n\n/**\n * Local credentials.\n * Local credentials, with memory cache and storage cache.\n * If the memory cache expires, the storage cache is automatically loaded.\n */\nexport class LocalCredentials {\n  private tokenSectionName: string\n\n  private storage: SimpleStorage\n\n  private credentials: Credentials | null = null\n\n  private singlePromise: SinglePromise = new SinglePromise()\n\n  /**\n   * constructor\n   * @param {LocalCredentialsOptions} options\n   */\n  constructor(options: LocalCredentialsOptions) {\n    this.tokenSectionName = options.tokenSectionName\n    this.storage = options.storage\n  }\n\n  public getStorageCredentialsSync(): Credentials | null {\n    let credentials: Credentials = null\n    const tokenStr: string = this.storage.getItemSync(this.tokenSectionName,)\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        credentials = JSON.parse(tokenStr)\n        if (credentials?.expires_at) {\n          credentials.expires_at = new Date(credentials.expires_at)\n        }\n      } catch (error) {\n        this.storage.removeItem(this.tokenSectionName)\n        credentials = null\n      }\n    }\n    return credentials\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   */\n  public async setCredentials(credentials?: Credentials): Promise<void> {\n    if (credentials?.expires_in) {\n      credentials.expires_at = new Date(Date.now() + (credentials.expires_in - 30) * 1000,)\n      if (this.storage) {\n        const tokenStr: string = JSON.stringify(credentials)\n        await this.storage.setItem(this.tokenSectionName, tokenStr)\n      }\n      this.credentials = credentials\n    } else {\n      if (this.storage) {\n        await this.storage.removeItem(this.tokenSectionName)\n      }\n      this.credentials = null\n    }\n  }\n\n  /**\n   * Get credentials.\n   * @return {Promise<Credentials | null>}\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('getCredentials', async () => {\n      if (isCredentialsExpired(this.credentials)) {\n        this.credentials = await this.getStorageCredentials()\n      }\n      return this.credentials\n    })\n  }\n\n  /**\n   * Get storage credentials.\n   */\n  private async getStorageCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('_getStorageCredentials', async () => {\n      let credentials: Credentials = null\n      const tokenStr: string = await this.storage.getItem(this.tokenSectionName,)\n      if (tokenStr !== undefined && tokenStr !== null) {\n        try {\n          credentials = JSON.parse(tokenStr)\n          if (credentials?.expires_at) {\n            credentials.expires_at = new Date(credentials.expires_at)\n          }\n        } catch (error) {\n          await this.storage.removeItem(this.tokenSectionName)\n          credentials = null\n        }\n      }\n      return credentials\n    })\n  }\n}\n\n/**\n * OAuth2Client\n */\nexport class OAuth2Client implements AuthClient {\n  private static defaultRetry = 2\n  private static minRetry = 0\n  private static maxRetry = 5\n  private static retryInterval = 1000\n\n  private apiOrigin: string\n  private clientId: string\n  private retry: number\n  private clientSecret?: string\n  private baseRequest: <T>(\n    url: string,\n    options?: RequestOptions,\n  ) => Promise<T>\n  private localCredentials: LocalCredentials\n  private storage: SimpleStorage\n  private deviceID?: string\n  private tokenInURL?: boolean\n  private refreshTokenFunc: (refreshToken?: string) => Promise<Credentials>\n  private headers?: { [key: string]: string }\n  private singlePromise: SinglePromise = new SinglePromise()\n\n  /**\n   * constructor\n   * @param {OAuth2ClientOptions} options\n   */\n  constructor(options: OAuth2ClientOptions) {\n    this.apiOrigin = options.apiOrigin\n    this.clientId = options.clientId\n    this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry)\n    if (options.baseRequest) {\n      this.baseRequest = options.baseRequest\n    } else {\n      this.baseRequest = defaultRequest\n    }\n    this.tokenInURL = options.tokenInURL\n    this.headers = options.headers\n    // @ts-ignore\n    this.storage = options.storage || defaultStorage\n    this.localCredentials = new LocalCredentials({\n      tokenSectionName: `credentials_${options.clientId}`,\n      storage: this.storage,\n    })\n    this.clientSecret = options.clientSecret\n    this.refreshTokenFunc =      options.refreshTokenFunc || this.defaultRefreshTokenFunc\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   * @return {Promise<void>}\n   */\n  public setCredentials(credentials?: Credentials): Promise<void> {\n    return this.localCredentials.setCredentials(credentials)\n  }\n\n  /**\n   * getAccessToken return a validate access token\n   */\n  public async getAccessToken(): Promise<string> {\n    const credentials: Credentials = await this.getCredentials()\n    if (credentials?.access_token) {\n      return Promise.resolve(credentials.access_token)\n    }\n    const respErr: ResponseError = { error: ErrorType.UNAUTHENTICATED }\n    return Promise.reject(respErr)\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(\n    url: string,\n    options?: AuthClientRequestOptions,\n  ): Promise<T> {\n    if (!options) {\n      options = {}\n    }\n    const retry: number = this.formatRetry(options.retry, this.retry)\n    options.headers = options.headers || {}\n    if (this.headers) {\n      options.headers = {\n        ...this.headers,\n        ...options.headers,\n      }\n    }\n    if (!options.headers[RequestIdHeaderName]) {\n      options.headers[RequestIdHeaderName] = generateRequestId()\n    }\n    if (!options.headers[DeviceIdHeaderName]) {\n      const deviceId = await this.getDeviceId()\n      options.headers[DeviceIdHeaderName] = deviceId\n    }\n    if (options?.withCredentials) {\n      const credentials = await this.getCredentials()\n      if (credentials) {\n        if (this.tokenInURL) {\n          if (url.indexOf('?') < 0) {\n            url += '?'\n          }\n          url += `access_token=${credentials.access_token}`\n        } else {\n          options.headers.Authorization =            `${credentials.token_type} ${credentials.access_token}`\n        }\n      }\n    } else {\n      if (this.clientId && url.indexOf('client_id') < 0) {\n        url += url.indexOf('?') < 0 ? '?' : '&'\n        url += `client_id=${this.clientId}`\n      }\n    }\n    if (url.startsWith('/')) {\n      url = this.apiOrigin + url\n    }\n    let response: T | null = null\n    const maxRequestTimes: number = retry + 1\n    for (\n      let requestTime = 0;\n      requestTime < maxRequestTimes;\n      requestTime++\n    ) {\n      try {\n        response = await this.baseRequest<T>(url, options)\n        break\n      } catch (responseError) {\n        if (options.withCredentials && responseError && responseError.error === ErrorType.UNAUTHENTICATED) {\n          await this.setCredentials(null)\n          return Promise.reject(responseError)\n        }\n\n        if (\n          requestTime === retry\n          || !responseError\n          || responseError.error !== 'unreachable'\n        ) {\n          return Promise.reject(responseError)\n        }\n      }\n      await this.sleep(OAuth2Client.retryInterval)\n    }\n    return response\n  }\n\n\n  /**\n   * Get credentials.\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    let credentials: Credentials = await this.localCredentials.getCredentials()\n    if (isCredentialsExpired(credentials)) {\n      if (credentials && credentials.scope === 'anonymous') {\n        credentials = await this.anonymousSignIn(credentials)\n      } else {\n        credentials = await this.refreshToken(credentials)\n      }\n    }\n    return credentials\n  }\n\n  public getCredentialsSync(): Credentials | null {\n    const credentials: Credentials = this.localCredentials.getStorageCredentialsSync()\n    return credentials\n  }\n\n  public getCredentialsAsync(): Promise<Credentials | null> {\n    return this.localCredentials.getCredentials()\n  }\n\n  public async getScope(): Promise<string> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      return this.unAuthenticatedError('credentials not found')\n    }\n    return credentials.scope\n  }\n\n  public async getGroups(): Promise<string[]> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      return this.unAuthenticatedError('credentials not found')\n    }\n    return credentials.groups\n  }\n\n  /**\n   * Check retry value.\n   * @param {number} retry\n   * @return {number}\n   */\n  private checkRetry(retry: number): number {\n    let responseError: ResponseError | null = null\n    if (\n      typeof retry !== 'number'\n      || retry < OAuth2Client.minRetry\n      || retry > OAuth2Client.maxRetry\n    ) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: 'wrong options param: retry',\n      }\n    }\n    if (responseError) {\n      throw responseError\n    }\n    return retry\n  }\n\n  /**\n   * Format retry value.\n   * @param {number} retry\n   * @param {number} defaultVale\n   * @return {number}\n   */\n  private formatRetry(retry: number, defaultVale: number): number {\n    if (typeof retry === 'undefined') {\n      return defaultVale\n    }\n    return this.checkRetry(retry)\n  }\n\n  /**\n   * Sleep.\n   * @param {number} ms\n   * @return {Promise<void>}\n   */\n  private async sleep(ms: number): Promise<void> {\n    return new Promise<void>((resolve) => {\n      setTimeout(() => {\n        resolve()\n      }, ms)\n    })\n  }\n\n  /**\n   * Refresh expired token.\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async refreshToken(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_refreshToken', async () => {\n      if (!credentials || !credentials.refresh_token) {\n        return this.unAuthenticatedError('no refresh token found in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.refreshTokenFunc(credentials.refresh_token,)\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * anonymous signIn\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async anonymousSignIn(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_anonymous', async () => {\n      if (!credentials || credentials.scope !== 'anonymous') {\n        return this.unAuthenticatedError('no anonymous in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.request('/auth/v1/signin/anonymously', {\n          method: 'POST',\n          body: {\n            client_id: this.clientId,\n            client_secret: this.clientSecret,\n          },\n        })\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * Default refresh token function.\n   * @param {string} refreshToken\n   * @return {Promise<Credentials>}\n   */\n  private defaultRefreshTokenFunc(refreshToken?: string,): Promise<Credentials> {\n    if (refreshToken === undefined || refreshToken === '') {\n      return this.unAuthenticatedError('refresh token not found')\n    }\n    return this.request('/auth/v1/token', {\n      method: 'POST',\n      body: {\n        client_id: this.clientId,\n        client_secret: this.clientSecret,\n        grant_type: 'refresh_token',\n        refresh_token: refreshToken,\n      },\n    })\n  }\n\n  /**\n   * Get deviceId\n   */\n  private async getDeviceId(): Promise<string> {\n    if (this.deviceID) {\n      return this.deviceID\n    }\n    let deviceId: string = await this.storage.getItem(DeviceIdSectionName,)\n    if (!(typeof deviceId === 'string'\n      && deviceId.length >= 16\n      && deviceId.length <= 48)) {\n      deviceId = uuidv4()\n      await this.storage.setItem(DeviceIdSectionName, deviceId)\n    }\n    this.deviceID = deviceId\n    return deviceId\n  }\n  /**\n   * Generate unAuthenticated error.\n   * @param {string} err\n   * @return {Promise<T>}\n   */\n  private unAuthenticatedError<T>(err?: string): Promise<T> {\n    const respErr: ResponseError = {\n      error: ErrorType.UNAUTHENTICATED,\n      error_description: err,\n    }\n    return Promise.reject(respErr)\n  }\n}\n"]}