@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.
- package/.eslintrc.js +15 -0
- package/dist/cjs/auth/apis.d.ts +3 -3
- package/dist/cjs/auth/apis.js +69 -69
- package/dist/cjs/captcha/captcha.d.ts +9 -9
- package/dist/cjs/captcha/captcha.js +43 -46
- package/dist/cjs/index.d.ts +3 -3
- package/dist/cjs/index.js +6 -6
- package/dist/cjs/oauth2client/interface.d.ts +1 -1
- package/dist/cjs/oauth2client/interface.js +1 -1
- package/dist/cjs/oauth2client/models.js +1 -1
- package/dist/cjs/oauth2client/oauth2client.d.ts +31 -31
- package/dist/cjs/oauth2client/oauth2client.js +229 -229
- package/dist/cjs/utils/function/single-promise.d.ts +2 -2
- package/dist/cjs/utils/function/single-promise.js +40 -33
- package/dist/cjs/utils/uuid.js +2 -2
- package/dist/esm/auth/apis.d.ts +3 -3
- package/dist/esm/auth/apis.js +69 -69
- package/dist/esm/captcha/captcha.d.ts +9 -9
- package/dist/esm/captcha/captcha.js +44 -47
- package/dist/esm/index.d.ts +3 -3
- package/dist/esm/index.js +5 -5
- package/dist/esm/oauth2client/interface.d.ts +1 -1
- package/dist/esm/oauth2client/interface.js +1 -1
- package/dist/esm/oauth2client/models.js +1 -1
- package/dist/esm/oauth2client/oauth2client.d.ts +31 -31
- package/dist/esm/oauth2client/oauth2client.js +229 -229
- package/dist/esm/utils/function/single-promise.d.ts +2 -2
- package/dist/esm/utils/function/single-promise.js +40 -33
- package/dist/esm/utils/uuid.js +2 -2
- package/package.json +13 -6
- package/src/auth/apis.ts +135 -158
- package/src/captcha/captcha.ts +71 -78
- package/src/index.ts +13 -14
- package/src/oauth2client/interface.ts +5 -5
- package/src/oauth2client/models.ts +38 -38
- package/src/oauth2client/oauth2client.ts +255 -268
- package/src/utils/function/single-promise.ts +22 -21
- package/src/utils/uuid.ts +4 -4
- package/.eslintrc +0 -26
|
@@ -54,56 +54,58 @@ var single_promise_1 = require("../utils/function/single-promise");
|
|
|
54
54
|
var RequestIdHeaderName = 'x-request-id';
|
|
55
55
|
var DeviceIdHeaderName = 'x-device-id';
|
|
56
56
|
var DeviceIdSectionName = 'device_id';
|
|
57
|
-
exports.defaultRequest = function (url, options) {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
copyOptions.method
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
copyOptions.body
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
57
|
+
exports.defaultRequest = function (url, options) {
|
|
58
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
59
|
+
var result, responseError, copyOptions, responseResult, jsonResponse, error_1;
|
|
60
|
+
return __generator(this, function (_a) {
|
|
61
|
+
switch (_a.label) {
|
|
62
|
+
case 0:
|
|
63
|
+
result = null;
|
|
64
|
+
responseError = null;
|
|
65
|
+
_a.label = 1;
|
|
66
|
+
case 1:
|
|
67
|
+
_a.trys.push([1, 4, , 5]);
|
|
68
|
+
copyOptions = Object.assign({}, options);
|
|
69
|
+
if (!copyOptions.method) {
|
|
70
|
+
copyOptions.method = 'GET';
|
|
71
|
+
}
|
|
72
|
+
if (copyOptions.body && typeof copyOptions.body !== 'string') {
|
|
73
|
+
copyOptions.body = JSON.stringify(copyOptions.body);
|
|
74
|
+
}
|
|
75
|
+
return [4, fetch(url, copyOptions)];
|
|
76
|
+
case 2:
|
|
77
|
+
responseResult = _a.sent();
|
|
78
|
+
return [4, responseResult.json()];
|
|
79
|
+
case 3:
|
|
80
|
+
jsonResponse = _a.sent();
|
|
81
|
+
if (jsonResponse === null || jsonResponse === void 0 ? void 0 : jsonResponse.error) {
|
|
82
|
+
responseError = jsonResponse;
|
|
83
|
+
responseError.error_uri = new URL(url).pathname;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
result = jsonResponse;
|
|
87
|
+
}
|
|
88
|
+
return [3, 5];
|
|
89
|
+
case 4:
|
|
90
|
+
error_1 = _a.sent();
|
|
91
|
+
responseError = {
|
|
92
|
+
error: consts_1.ErrorType.UNREACHABLE,
|
|
93
|
+
error_description: error_1.message,
|
|
94
|
+
error_uri: new URL(url).pathname,
|
|
95
|
+
};
|
|
96
|
+
return [3, 5];
|
|
97
|
+
case 5:
|
|
98
|
+
if (responseError) {
|
|
99
|
+
throw responseError;
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
return [2, result];
|
|
103
|
+
}
|
|
104
|
+
return [2];
|
|
105
|
+
}
|
|
106
|
+
});
|
|
105
107
|
});
|
|
106
|
-
}
|
|
108
|
+
};
|
|
107
109
|
exports.toResponseError = function (error, options) {
|
|
108
110
|
var responseError;
|
|
109
111
|
var formatOptions = options || {};
|
|
@@ -177,11 +179,28 @@ function isCredentialsExpired(credentials) {
|
|
|
177
179
|
}
|
|
178
180
|
var LocalCredentials = (function () {
|
|
179
181
|
function LocalCredentials(options) {
|
|
180
|
-
this.
|
|
181
|
-
this.
|
|
182
|
-
this.
|
|
183
|
-
this.
|
|
182
|
+
this.credentials = null;
|
|
183
|
+
this.singlePromise = new single_promise_1.SinglePromise();
|
|
184
|
+
this.tokenSectionName = options.tokenSectionName;
|
|
185
|
+
this.storage = options.storage;
|
|
184
186
|
}
|
|
187
|
+
LocalCredentials.prototype.getStorageCredentialsSync = function () {
|
|
188
|
+
var credentials = null;
|
|
189
|
+
var tokenStr = this.storage.getItemSync(this.tokenSectionName);
|
|
190
|
+
if (tokenStr !== undefined && tokenStr !== null) {
|
|
191
|
+
try {
|
|
192
|
+
credentials = JSON.parse(tokenStr);
|
|
193
|
+
if (credentials === null || credentials === void 0 ? void 0 : credentials.expires_at) {
|
|
194
|
+
credentials.expires_at = new Date(credentials.expires_at);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
catch (error) {
|
|
198
|
+
this.storage.removeItem(this.tokenSectionName);
|
|
199
|
+
credentials = null;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
return credentials;
|
|
203
|
+
};
|
|
185
204
|
LocalCredentials.prototype.setCredentials = function (credentials) {
|
|
186
205
|
return __awaiter(this, void 0, void 0, function () {
|
|
187
206
|
var tokenStr;
|
|
@@ -190,23 +209,23 @@ var LocalCredentials = (function () {
|
|
|
190
209
|
case 0:
|
|
191
210
|
if (!(credentials === null || credentials === void 0 ? void 0 : credentials.expires_in)) return [3, 3];
|
|
192
211
|
credentials.expires_at = new Date(Date.now() + (credentials.expires_in - 30) * 1000);
|
|
193
|
-
if (!this.
|
|
212
|
+
if (!this.storage) return [3, 2];
|
|
194
213
|
tokenStr = JSON.stringify(credentials);
|
|
195
|
-
return [4, this.
|
|
214
|
+
return [4, this.storage.setItem(this.tokenSectionName, tokenStr)];
|
|
196
215
|
case 1:
|
|
197
216
|
_a.sent();
|
|
198
217
|
_a.label = 2;
|
|
199
218
|
case 2:
|
|
200
|
-
this.
|
|
219
|
+
this.credentials = credentials;
|
|
201
220
|
return [3, 6];
|
|
202
221
|
case 3:
|
|
203
|
-
if (!this.
|
|
204
|
-
return [4, this.
|
|
222
|
+
if (!this.storage) return [3, 5];
|
|
223
|
+
return [4, this.storage.removeItem(this.tokenSectionName)];
|
|
205
224
|
case 4:
|
|
206
225
|
_a.sent();
|
|
207
226
|
_a.label = 5;
|
|
208
227
|
case 5:
|
|
209
|
-
this.
|
|
228
|
+
this.credentials = null;
|
|
210
229
|
_a.label = 6;
|
|
211
230
|
case 6: return [2];
|
|
212
231
|
}
|
|
@@ -217,35 +236,35 @@ var LocalCredentials = (function () {
|
|
|
217
236
|
return __awaiter(this, void 0, void 0, function () {
|
|
218
237
|
var _this = this;
|
|
219
238
|
return __generator(this, function (_a) {
|
|
220
|
-
return [2, this.
|
|
239
|
+
return [2, this.singlePromise.run('getCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
|
|
221
240
|
var _a;
|
|
222
241
|
return __generator(this, function (_b) {
|
|
223
242
|
switch (_b.label) {
|
|
224
243
|
case 0:
|
|
225
|
-
if (!isCredentialsExpired(this.
|
|
244
|
+
if (!isCredentialsExpired(this.credentials)) return [3, 2];
|
|
226
245
|
_a = this;
|
|
227
|
-
return [4, this.
|
|
246
|
+
return [4, this.getStorageCredentials()];
|
|
228
247
|
case 1:
|
|
229
|
-
_a.
|
|
248
|
+
_a.credentials = _b.sent();
|
|
230
249
|
_b.label = 2;
|
|
231
|
-
case 2: return [2, this.
|
|
250
|
+
case 2: return [2, this.credentials];
|
|
232
251
|
}
|
|
233
252
|
});
|
|
234
253
|
}); })];
|
|
235
254
|
});
|
|
236
255
|
});
|
|
237
256
|
};
|
|
238
|
-
LocalCredentials.prototype.
|
|
257
|
+
LocalCredentials.prototype.getStorageCredentials = function () {
|
|
239
258
|
return __awaiter(this, void 0, void 0, function () {
|
|
240
259
|
var _this = this;
|
|
241
260
|
return __generator(this, function (_a) {
|
|
242
|
-
return [2, this.
|
|
261
|
+
return [2, this.singlePromise.run('_getStorageCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
|
|
243
262
|
var credentials, tokenStr, error_2;
|
|
244
263
|
return __generator(this, function (_a) {
|
|
245
264
|
switch (_a.label) {
|
|
246
265
|
case 0:
|
|
247
266
|
credentials = null;
|
|
248
|
-
return [4, this.
|
|
267
|
+
return [4, this.storage.getItem(this.tokenSectionName)];
|
|
249
268
|
case 1:
|
|
250
269
|
tokenStr = _a.sent();
|
|
251
270
|
if (!(tokenStr !== undefined && tokenStr !== null)) return [3, 5];
|
|
@@ -259,7 +278,7 @@ var LocalCredentials = (function () {
|
|
|
259
278
|
return [3, 5];
|
|
260
279
|
case 3:
|
|
261
280
|
error_2 = _a.sent();
|
|
262
|
-
return [4, this.
|
|
281
|
+
return [4, this.storage.removeItem(this.tokenSectionName)];
|
|
263
282
|
case 4:
|
|
264
283
|
_a.sent();
|
|
265
284
|
credentials = null;
|
|
@@ -271,64 +290,47 @@ var LocalCredentials = (function () {
|
|
|
271
290
|
});
|
|
272
291
|
});
|
|
273
292
|
};
|
|
274
|
-
LocalCredentials.prototype._getStorageCredentialsSync = function () {
|
|
275
|
-
var credentials = null;
|
|
276
|
-
var tokenStr = this._storage.getItemSync(this._tokenSectionName);
|
|
277
|
-
if (tokenStr !== undefined && tokenStr !== null) {
|
|
278
|
-
try {
|
|
279
|
-
credentials = JSON.parse(tokenStr);
|
|
280
|
-
if (credentials === null || credentials === void 0 ? void 0 : credentials.expires_at) {
|
|
281
|
-
credentials.expires_at = new Date(credentials.expires_at);
|
|
282
|
-
}
|
|
283
|
-
}
|
|
284
|
-
catch (error) {
|
|
285
|
-
this._storage.removeItem(this._tokenSectionName);
|
|
286
|
-
credentials = null;
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
return credentials;
|
|
290
|
-
};
|
|
291
293
|
return LocalCredentials;
|
|
292
294
|
}());
|
|
293
295
|
exports.LocalCredentials = LocalCredentials;
|
|
294
296
|
var OAuth2Client = (function () {
|
|
295
297
|
function OAuth2Client(options) {
|
|
296
|
-
this.
|
|
297
|
-
this.
|
|
298
|
-
this.
|
|
299
|
-
this.
|
|
300
|
-
if (options.baseRequest
|
|
301
|
-
this.
|
|
298
|
+
this.singlePromise = new single_promise_1.SinglePromise();
|
|
299
|
+
this.apiOrigin = options.apiOrigin;
|
|
300
|
+
this.clientId = options.clientId;
|
|
301
|
+
this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry);
|
|
302
|
+
if (options.baseRequest) {
|
|
303
|
+
this.baseRequest = options.baseRequest;
|
|
302
304
|
}
|
|
303
305
|
else {
|
|
304
|
-
this.
|
|
306
|
+
this.baseRequest = exports.defaultRequest;
|
|
305
307
|
}
|
|
306
|
-
this.
|
|
307
|
-
this.
|
|
308
|
-
this.
|
|
309
|
-
this.
|
|
310
|
-
tokenSectionName:
|
|
311
|
-
storage: this.
|
|
308
|
+
this.tokenInURL = options.tokenInURL;
|
|
309
|
+
this.headers = options.headers;
|
|
310
|
+
this.storage = options.storage || exports.defaultStorage;
|
|
311
|
+
this.localCredentials = new LocalCredentials({
|
|
312
|
+
tokenSectionName: "credentials_" + options.clientId,
|
|
313
|
+
storage: this.storage,
|
|
312
314
|
});
|
|
313
|
-
this.
|
|
314
|
-
this.
|
|
315
|
-
options.refreshTokenFunc || this._defaultRefreshTokenFunc;
|
|
315
|
+
this.clientSecret = options.clientSecret;
|
|
316
|
+
this.refreshTokenFunc = options.refreshTokenFunc || this.defaultRefreshTokenFunc;
|
|
316
317
|
}
|
|
317
318
|
OAuth2Client.prototype.setCredentials = function (credentials) {
|
|
318
|
-
return this.
|
|
319
|
+
return this.localCredentials.setCredentials(credentials);
|
|
319
320
|
};
|
|
320
321
|
OAuth2Client.prototype.getAccessToken = function () {
|
|
321
322
|
return __awaiter(this, void 0, void 0, function () {
|
|
322
|
-
var credentials;
|
|
323
|
+
var credentials, respErr;
|
|
323
324
|
return __generator(this, function (_a) {
|
|
324
325
|
switch (_a.label) {
|
|
325
|
-
case 0: return [4, this.
|
|
326
|
+
case 0: return [4, this.getCredentials()];
|
|
326
327
|
case 1:
|
|
327
328
|
credentials = _a.sent();
|
|
328
329
|
if (credentials === null || credentials === void 0 ? void 0 : credentials.access_token) {
|
|
329
330
|
return [2, Promise.resolve(credentials.access_token)];
|
|
330
331
|
}
|
|
331
|
-
|
|
332
|
+
respErr = { error: consts_1.ErrorType.UNAUTHENTICATED };
|
|
333
|
+
return [2, Promise.reject(respErr)];
|
|
332
334
|
}
|
|
333
335
|
});
|
|
334
336
|
});
|
|
@@ -342,47 +344,46 @@ var OAuth2Client = (function () {
|
|
|
342
344
|
if (!options) {
|
|
343
345
|
options = {};
|
|
344
346
|
}
|
|
345
|
-
retry = this.
|
|
347
|
+
retry = this.formatRetry(options.retry, this.retry);
|
|
346
348
|
options.headers = options.headers || {};
|
|
347
|
-
if (this.
|
|
348
|
-
options.headers = __assign(__assign({}, this.
|
|
349
|
+
if (this.headers) {
|
|
350
|
+
options.headers = __assign(__assign({}, this.headers), options.headers);
|
|
349
351
|
}
|
|
350
352
|
if (!options.headers[RequestIdHeaderName]) {
|
|
351
353
|
options.headers[RequestIdHeaderName] = generateRequestId();
|
|
352
354
|
}
|
|
353
355
|
if (!!options.headers[DeviceIdHeaderName]) return [3, 2];
|
|
354
|
-
return [4, this.
|
|
356
|
+
return [4, this.getDeviceId()];
|
|
355
357
|
case 1:
|
|
356
358
|
deviceId = _a.sent();
|
|
357
359
|
options.headers[DeviceIdHeaderName] = deviceId;
|
|
358
360
|
_a.label = 2;
|
|
359
361
|
case 2:
|
|
360
362
|
if (!(options === null || options === void 0 ? void 0 : options.withCredentials)) return [3, 4];
|
|
361
|
-
return [4, this.
|
|
363
|
+
return [4, this.getCredentials()];
|
|
362
364
|
case 3:
|
|
363
365
|
credentials = _a.sent();
|
|
364
366
|
if (credentials) {
|
|
365
|
-
if (this.
|
|
367
|
+
if (this.tokenInURL) {
|
|
366
368
|
if (url.indexOf('?') < 0) {
|
|
367
369
|
url += '?';
|
|
368
370
|
}
|
|
369
|
-
url +=
|
|
371
|
+
url += "access_token=" + credentials.access_token;
|
|
370
372
|
}
|
|
371
373
|
else {
|
|
372
|
-
options.headers
|
|
373
|
-
credentials.token_type + ' ' + credentials.access_token;
|
|
374
|
+
options.headers.Authorization = credentials.token_type + " " + credentials.access_token;
|
|
374
375
|
}
|
|
375
376
|
}
|
|
376
377
|
return [3, 5];
|
|
377
378
|
case 4:
|
|
378
|
-
if (this.
|
|
379
|
+
if (this.clientId && url.indexOf('client_id') < 0) {
|
|
379
380
|
url += url.indexOf('?') < 0 ? '?' : '&';
|
|
380
|
-
url +=
|
|
381
|
+
url += "client_id=" + this.clientId;
|
|
381
382
|
}
|
|
382
383
|
_a.label = 5;
|
|
383
384
|
case 5:
|
|
384
385
|
if (url.startsWith('/')) {
|
|
385
|
-
url = this.
|
|
386
|
+
url = this.apiOrigin + url;
|
|
386
387
|
}
|
|
387
388
|
response = null;
|
|
388
389
|
maxRequestTimes = retry + 1;
|
|
@@ -393,7 +394,7 @@ var OAuth2Client = (function () {
|
|
|
393
394
|
_a.label = 7;
|
|
394
395
|
case 7:
|
|
395
396
|
_a.trys.push([7, 9, , 12]);
|
|
396
|
-
return [4, this.
|
|
397
|
+
return [4, this.baseRequest(url, options)];
|
|
397
398
|
case 8:
|
|
398
399
|
response = _a.sent();
|
|
399
400
|
return [3, 15];
|
|
@@ -405,13 +406,13 @@ var OAuth2Client = (function () {
|
|
|
405
406
|
_a.sent();
|
|
406
407
|
return [2, Promise.reject(responseError_1)];
|
|
407
408
|
case 11:
|
|
408
|
-
if (requestTime === retry
|
|
409
|
-
!responseError_1
|
|
410
|
-
responseError_1.error !== 'unreachable') {
|
|
409
|
+
if (requestTime === retry
|
|
410
|
+
|| !responseError_1
|
|
411
|
+
|| responseError_1.error !== 'unreachable') {
|
|
411
412
|
return [2, Promise.reject(responseError_1)];
|
|
412
413
|
}
|
|
413
414
|
return [3, 12];
|
|
414
|
-
case 12: return [4, this.
|
|
415
|
+
case 12: return [4, this.sleep(OAuth2Client.retryInterval)];
|
|
415
416
|
case 13:
|
|
416
417
|
_a.sent();
|
|
417
418
|
_a.label = 14;
|
|
@@ -423,11 +424,73 @@ var OAuth2Client = (function () {
|
|
|
423
424
|
});
|
|
424
425
|
});
|
|
425
426
|
};
|
|
426
|
-
OAuth2Client.prototype.
|
|
427
|
+
OAuth2Client.prototype.getCredentials = function () {
|
|
428
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
429
|
+
var credentials;
|
|
430
|
+
return __generator(this, function (_a) {
|
|
431
|
+
switch (_a.label) {
|
|
432
|
+
case 0: return [4, this.localCredentials.getCredentials()];
|
|
433
|
+
case 1:
|
|
434
|
+
credentials = _a.sent();
|
|
435
|
+
if (!isCredentialsExpired(credentials)) return [3, 5];
|
|
436
|
+
if (!(credentials && credentials.scope === 'anonymous')) return [3, 3];
|
|
437
|
+
return [4, this.anonymousSignIn(credentials)];
|
|
438
|
+
case 2:
|
|
439
|
+
credentials = _a.sent();
|
|
440
|
+
return [3, 5];
|
|
441
|
+
case 3: return [4, this.refreshToken(credentials)];
|
|
442
|
+
case 4:
|
|
443
|
+
credentials = _a.sent();
|
|
444
|
+
_a.label = 5;
|
|
445
|
+
case 5: return [2, credentials];
|
|
446
|
+
}
|
|
447
|
+
});
|
|
448
|
+
});
|
|
449
|
+
};
|
|
450
|
+
OAuth2Client.prototype.getCredentialsSync = function () {
|
|
451
|
+
var credentials = this.localCredentials.getStorageCredentialsSync();
|
|
452
|
+
return credentials;
|
|
453
|
+
};
|
|
454
|
+
OAuth2Client.prototype.getCredentialsAsync = function () {
|
|
455
|
+
return this.localCredentials.getCredentials();
|
|
456
|
+
};
|
|
457
|
+
OAuth2Client.prototype.getScope = function () {
|
|
458
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
459
|
+
var credentials;
|
|
460
|
+
return __generator(this, function (_a) {
|
|
461
|
+
switch (_a.label) {
|
|
462
|
+
case 0: return [4, this.localCredentials.getCredentials()];
|
|
463
|
+
case 1:
|
|
464
|
+
credentials = _a.sent();
|
|
465
|
+
if (!credentials) {
|
|
466
|
+
return [2, this.unAuthenticatedError('credentials not found')];
|
|
467
|
+
}
|
|
468
|
+
return [2, credentials.scope];
|
|
469
|
+
}
|
|
470
|
+
});
|
|
471
|
+
});
|
|
472
|
+
};
|
|
473
|
+
OAuth2Client.prototype.getGroups = function () {
|
|
474
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
475
|
+
var credentials;
|
|
476
|
+
return __generator(this, function (_a) {
|
|
477
|
+
switch (_a.label) {
|
|
478
|
+
case 0: return [4, this.localCredentials.getCredentials()];
|
|
479
|
+
case 1:
|
|
480
|
+
credentials = _a.sent();
|
|
481
|
+
if (!credentials) {
|
|
482
|
+
return [2, this.unAuthenticatedError('credentials not found')];
|
|
483
|
+
}
|
|
484
|
+
return [2, credentials.groups];
|
|
485
|
+
}
|
|
486
|
+
});
|
|
487
|
+
});
|
|
488
|
+
};
|
|
489
|
+
OAuth2Client.prototype.checkRetry = function (retry) {
|
|
427
490
|
var responseError = null;
|
|
428
|
-
if (typeof retry !== 'number'
|
|
429
|
-
retry < OAuth2Client.
|
|
430
|
-
retry > OAuth2Client.
|
|
491
|
+
if (typeof retry !== 'number'
|
|
492
|
+
|| retry < OAuth2Client.minRetry
|
|
493
|
+
|| retry > OAuth2Client.maxRetry) {
|
|
431
494
|
responseError = {
|
|
432
495
|
error: consts_1.ErrorType.UNREACHABLE,
|
|
433
496
|
error_description: 'wrong options param: retry',
|
|
@@ -438,15 +501,13 @@ var OAuth2Client = (function () {
|
|
|
438
501
|
}
|
|
439
502
|
return retry;
|
|
440
503
|
};
|
|
441
|
-
OAuth2Client.prototype.
|
|
504
|
+
OAuth2Client.prototype.formatRetry = function (retry, defaultVale) {
|
|
442
505
|
if (typeof retry === 'undefined') {
|
|
443
506
|
return defaultVale;
|
|
444
507
|
}
|
|
445
|
-
|
|
446
|
-
return this._checkRetry(retry);
|
|
447
|
-
}
|
|
508
|
+
return this.checkRetry(retry);
|
|
448
509
|
};
|
|
449
|
-
OAuth2Client.prototype.
|
|
510
|
+
OAuth2Client.prototype.sleep = function (ms) {
|
|
450
511
|
return __awaiter(this, void 0, void 0, function () {
|
|
451
512
|
return __generator(this, function (_a) {
|
|
452
513
|
return [2, new Promise(function (resolve) {
|
|
@@ -457,35 +518,35 @@ var OAuth2Client = (function () {
|
|
|
457
518
|
});
|
|
458
519
|
});
|
|
459
520
|
};
|
|
460
|
-
OAuth2Client.prototype.
|
|
521
|
+
OAuth2Client.prototype.refreshToken = function (credentials) {
|
|
461
522
|
return __awaiter(this, void 0, void 0, function () {
|
|
462
523
|
var _this = this;
|
|
463
524
|
return __generator(this, function (_a) {
|
|
464
|
-
return [2, this.
|
|
525
|
+
return [2, this.singlePromise.run('_refreshToken', function () { return __awaiter(_this, void 0, void 0, function () {
|
|
465
526
|
var newCredentials, error_3;
|
|
466
527
|
return __generator(this, function (_a) {
|
|
467
528
|
switch (_a.label) {
|
|
468
529
|
case 0:
|
|
469
530
|
if (!credentials || !credentials.refresh_token) {
|
|
470
|
-
return [2, this.
|
|
531
|
+
return [2, this.unAuthenticatedError('no refresh token found in credentials')];
|
|
471
532
|
}
|
|
472
533
|
_a.label = 1;
|
|
473
534
|
case 1:
|
|
474
535
|
_a.trys.push([1, 4, , 7]);
|
|
475
|
-
return [4, this.
|
|
536
|
+
return [4, this.refreshTokenFunc(credentials.refresh_token)];
|
|
476
537
|
case 2:
|
|
477
538
|
newCredentials = _a.sent();
|
|
478
|
-
return [4, this.
|
|
539
|
+
return [4, this.localCredentials.setCredentials(newCredentials)];
|
|
479
540
|
case 3:
|
|
480
541
|
_a.sent();
|
|
481
542
|
return [2, newCredentials];
|
|
482
543
|
case 4:
|
|
483
544
|
error_3 = _a.sent();
|
|
484
545
|
if (!(error_3.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
|
|
485
|
-
return [4, this.
|
|
546
|
+
return [4, this.localCredentials.setCredentials(null)];
|
|
486
547
|
case 5:
|
|
487
548
|
_a.sent();
|
|
488
|
-
return [2, this.
|
|
549
|
+
return [2, this.unAuthenticatedError(error_3.error_description)];
|
|
489
550
|
case 6: return [2, Promise.reject(error_3)];
|
|
490
551
|
case 7: return [2];
|
|
491
552
|
}
|
|
@@ -494,17 +555,17 @@ var OAuth2Client = (function () {
|
|
|
494
555
|
});
|
|
495
556
|
});
|
|
496
557
|
};
|
|
497
|
-
OAuth2Client.prototype.
|
|
558
|
+
OAuth2Client.prototype.anonymousSignIn = function (credentials) {
|
|
498
559
|
return __awaiter(this, void 0, void 0, function () {
|
|
499
560
|
var _this = this;
|
|
500
561
|
return __generator(this, function (_a) {
|
|
501
|
-
return [2, this.
|
|
562
|
+
return [2, this.singlePromise.run('_anonymous', function () { return __awaiter(_this, void 0, void 0, function () {
|
|
502
563
|
var newCredentials, error_4;
|
|
503
564
|
return __generator(this, function (_a) {
|
|
504
565
|
switch (_a.label) {
|
|
505
566
|
case 0:
|
|
506
567
|
if (!credentials || credentials.scope !== 'anonymous') {
|
|
507
|
-
return [2, this.
|
|
568
|
+
return [2, this.unAuthenticatedError('no anonymous in credentials')];
|
|
508
569
|
}
|
|
509
570
|
_a.label = 1;
|
|
510
571
|
case 1:
|
|
@@ -512,23 +573,23 @@ var OAuth2Client = (function () {
|
|
|
512
573
|
return [4, this.request('/auth/v1/signin/anonymously', {
|
|
513
574
|
method: 'POST',
|
|
514
575
|
body: {
|
|
515
|
-
client_id: this.
|
|
516
|
-
client_secret: this.
|
|
576
|
+
client_id: this.clientId,
|
|
577
|
+
client_secret: this.clientSecret,
|
|
517
578
|
},
|
|
518
579
|
})];
|
|
519
580
|
case 2:
|
|
520
581
|
newCredentials = _a.sent();
|
|
521
|
-
return [4, this.
|
|
582
|
+
return [4, this.localCredentials.setCredentials(newCredentials)];
|
|
522
583
|
case 3:
|
|
523
584
|
_a.sent();
|
|
524
585
|
return [2, newCredentials];
|
|
525
586
|
case 4:
|
|
526
587
|
error_4 = _a.sent();
|
|
527
588
|
if (!(error_4.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
|
|
528
|
-
return [4, this.
|
|
589
|
+
return [4, this.localCredentials.setCredentials(null)];
|
|
529
590
|
case 5:
|
|
530
591
|
_a.sent();
|
|
531
|
-
return [2, this.
|
|
592
|
+
return [2, this.unAuthenticatedError(error_4.error_description)];
|
|
532
593
|
case 6: return [2, Promise.reject(error_4)];
|
|
533
594
|
case 7: return [2];
|
|
534
595
|
}
|
|
@@ -537,120 +598,59 @@ var OAuth2Client = (function () {
|
|
|
537
598
|
});
|
|
538
599
|
});
|
|
539
600
|
};
|
|
540
|
-
OAuth2Client.prototype.
|
|
601
|
+
OAuth2Client.prototype.defaultRefreshTokenFunc = function (refreshToken) {
|
|
541
602
|
if (refreshToken === undefined || refreshToken === '') {
|
|
542
|
-
return this.
|
|
603
|
+
return this.unAuthenticatedError('refresh token not found');
|
|
543
604
|
}
|
|
544
605
|
return this.request('/auth/v1/token', {
|
|
545
606
|
method: 'POST',
|
|
546
607
|
body: {
|
|
547
|
-
client_id: this.
|
|
548
|
-
client_secret: this.
|
|
608
|
+
client_id: this.clientId,
|
|
609
|
+
client_secret: this.clientSecret,
|
|
549
610
|
grant_type: 'refresh_token',
|
|
550
611
|
refresh_token: refreshToken,
|
|
551
612
|
},
|
|
552
613
|
});
|
|
553
614
|
};
|
|
554
|
-
OAuth2Client.prototype.
|
|
555
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
556
|
-
var credentials;
|
|
557
|
-
return __generator(this, function (_a) {
|
|
558
|
-
switch (_a.label) {
|
|
559
|
-
case 0: return [4, this._localCredentials.getCredentials()];
|
|
560
|
-
case 1:
|
|
561
|
-
credentials = _a.sent();
|
|
562
|
-
if (!isCredentialsExpired(credentials)) return [3, 5];
|
|
563
|
-
if (!(credentials && credentials.scope === 'anonymous')) return [3, 3];
|
|
564
|
-
return [4, this._anonymousSignIn(credentials)];
|
|
565
|
-
case 2:
|
|
566
|
-
credentials = _a.sent();
|
|
567
|
-
return [3, 5];
|
|
568
|
-
case 3: return [4, this._refreshToken(credentials)];
|
|
569
|
-
case 4:
|
|
570
|
-
credentials = _a.sent();
|
|
571
|
-
_a.label = 5;
|
|
572
|
-
case 5: return [2, credentials];
|
|
573
|
-
}
|
|
574
|
-
});
|
|
575
|
-
});
|
|
576
|
-
};
|
|
577
|
-
OAuth2Client.prototype.getCredentialsSync = function () {
|
|
578
|
-
var credentials = this._localCredentials._getStorageCredentialsSync();
|
|
579
|
-
return credentials;
|
|
580
|
-
};
|
|
581
|
-
OAuth2Client.prototype.getCredentialsAsync = function () {
|
|
582
|
-
return this._localCredentials.getCredentials();
|
|
583
|
-
};
|
|
584
|
-
OAuth2Client.prototype.getScope = function () {
|
|
585
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
586
|
-
var credentials;
|
|
587
|
-
return __generator(this, function (_a) {
|
|
588
|
-
switch (_a.label) {
|
|
589
|
-
case 0: return [4, this._localCredentials.getCredentials()];
|
|
590
|
-
case 1:
|
|
591
|
-
credentials = _a.sent();
|
|
592
|
-
if (credentials == null) {
|
|
593
|
-
return [2, this._unAuthenticatedError("credentials not found")];
|
|
594
|
-
}
|
|
595
|
-
return [2, credentials.scope];
|
|
596
|
-
}
|
|
597
|
-
});
|
|
598
|
-
});
|
|
599
|
-
};
|
|
600
|
-
OAuth2Client.prototype.getGroups = function () {
|
|
601
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
602
|
-
var credentials;
|
|
603
|
-
return __generator(this, function (_a) {
|
|
604
|
-
switch (_a.label) {
|
|
605
|
-
case 0: return [4, this._localCredentials.getCredentials()];
|
|
606
|
-
case 1:
|
|
607
|
-
credentials = _a.sent();
|
|
608
|
-
if (credentials == null) {
|
|
609
|
-
return [2, this._unAuthenticatedError("credentials not found")];
|
|
610
|
-
}
|
|
611
|
-
return [2, credentials.groups];
|
|
612
|
-
}
|
|
613
|
-
});
|
|
614
|
-
});
|
|
615
|
-
};
|
|
616
|
-
OAuth2Client.prototype._getDeviceId = function () {
|
|
615
|
+
OAuth2Client.prototype.getDeviceId = function () {
|
|
617
616
|
return __awaiter(this, void 0, void 0, function () {
|
|
618
617
|
var deviceId;
|
|
619
618
|
return __generator(this, function (_a) {
|
|
620
619
|
switch (_a.label) {
|
|
621
620
|
case 0:
|
|
622
|
-
if (this.
|
|
623
|
-
return [2, this.
|
|
621
|
+
if (this.deviceID) {
|
|
622
|
+
return [2, this.deviceID];
|
|
624
623
|
}
|
|
625
|
-
return [4, this.
|
|
624
|
+
return [4, this.storage.getItem(DeviceIdSectionName)];
|
|
626
625
|
case 1:
|
|
627
626
|
deviceId = _a.sent();
|
|
628
|
-
if (!!(typeof deviceId === 'string'
|
|
629
|
-
deviceId.length >= 16
|
|
630
|
-
deviceId.length <= 48)) return [3, 3];
|
|
627
|
+
if (!!(typeof deviceId === 'string'
|
|
628
|
+
&& deviceId.length >= 16
|
|
629
|
+
&& deviceId.length <= 48)) return [3, 3];
|
|
631
630
|
deviceId = uuid_1.uuidv4();
|
|
632
|
-
return [4, this.
|
|
631
|
+
return [4, this.storage.setItem(DeviceIdSectionName, deviceId)];
|
|
633
632
|
case 2:
|
|
634
633
|
_a.sent();
|
|
635
634
|
_a.label = 3;
|
|
636
635
|
case 3:
|
|
637
|
-
this.
|
|
636
|
+
this.deviceID = deviceId;
|
|
638
637
|
return [2, deviceId];
|
|
639
638
|
}
|
|
640
639
|
});
|
|
641
640
|
});
|
|
642
641
|
};
|
|
643
|
-
OAuth2Client.prototype.
|
|
644
|
-
|
|
642
|
+
OAuth2Client.prototype.unAuthenticatedError = function (err) {
|
|
643
|
+
var respErr = {
|
|
645
644
|
error: consts_1.ErrorType.UNAUTHENTICATED,
|
|
646
645
|
error_description: err,
|
|
647
|
-
}
|
|
646
|
+
};
|
|
647
|
+
return Promise.reject(respErr);
|
|
648
648
|
};
|
|
649
|
-
OAuth2Client.
|
|
650
|
-
OAuth2Client.
|
|
651
|
-
OAuth2Client.
|
|
652
|
-
OAuth2Client.
|
|
649
|
+
OAuth2Client.defaultRetry = 2;
|
|
650
|
+
OAuth2Client.minRetry = 0;
|
|
651
|
+
OAuth2Client.maxRetry = 5;
|
|
652
|
+
OAuth2Client.retryInterval = 1000;
|
|
653
653
|
return OAuth2Client;
|
|
654
654
|
}());
|
|
655
655
|
exports.OAuth2Client = OAuth2Client;
|
|
656
|
-
//# 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"]}
|
|
656
|
+
//# 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"]}
|