@cloudbase/app 1.5.3-alpha.0 → 1.8.1
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 +12 -0
- package/dist/cjs/constants/common.d.ts +1 -8
- package/dist/cjs/constants/common.js +5 -17
- package/dist/cjs/constants/events.js +2 -2
- package/dist/cjs/index.d.ts +0 -1
- package/dist/cjs/index.js +26 -29
- package/dist/cjs/libs/adapter.d.ts +1 -1
- package/dist/cjs/libs/adapter.js +1 -1
- package/dist/cjs/libs/cache.d.ts +1 -1
- package/dist/cjs/libs/cache.js +9 -14
- package/dist/cjs/libs/component.js +16 -14
- package/dist/cjs/libs/request.d.ts +0 -10
- package/dist/cjs/libs/request.js +61 -340
- package/dist/esm/constants/common.d.ts +1 -8
- package/dist/esm/constants/common.js +4 -15
- package/dist/esm/constants/events.js +2 -2
- package/dist/esm/index.d.ts +0 -1
- package/dist/esm/index.js +15 -17
- package/dist/esm/libs/adapter.d.ts +1 -1
- package/dist/esm/libs/adapter.js +1 -1
- package/dist/esm/libs/cache.d.ts +1 -1
- package/dist/esm/libs/cache.js +10 -15
- package/dist/esm/libs/component.js +16 -14
- package/dist/esm/libs/request.d.ts +0 -10
- package/dist/esm/libs/request.js +61 -340
- package/package.json +5 -16
- package/src/constants/common.ts +5 -19
- package/src/constants/events.ts +5 -5
- package/src/global.d.ts +1 -1
- package/src/index.ts +20 -22
- package/src/libs/adapter.ts +2 -2
- package/src/libs/cache.ts +8 -11
- package/src/libs/component.ts +42 -40
- package/src/libs/request.ts +54 -294
- package/.eslintrc +0 -29
package/dist/cjs/libs/request.js
CHANGED
|
@@ -25,7 +25,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
25
25
|
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
26
26
|
function step(op) {
|
|
27
27
|
if (f) throw new TypeError("Generator is already executing.");
|
|
28
|
-
while (_) try {
|
|
28
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
29
29
|
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
30
30
|
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
31
31
|
switch (op[0]) {
|
|
@@ -54,10 +54,9 @@ var __1 = require("..");
|
|
|
54
54
|
var cache_1 = require("./cache");
|
|
55
55
|
var events_1 = require("../constants/events");
|
|
56
56
|
var adapter_1 = require("./adapter");
|
|
57
|
-
var
|
|
57
|
+
var ERRORS = utilities_1.constants.ERRORS;
|
|
58
58
|
var genSeqId = utilities_1.utils.genSeqId, isFormData = utilities_1.utils.isFormData, formatUrl = utilities_1.utils.formatUrl, createSign = utilities_1.utils.createSign;
|
|
59
59
|
var RUNTIME = utilities_1.adapters.RUNTIME;
|
|
60
|
-
var uuid_1 = require("uuid");
|
|
61
60
|
var ACTIONS_WITHOUT_ACCESSTOKEN = [
|
|
62
61
|
'auth.getJwt',
|
|
63
62
|
'auth.logout',
|
|
@@ -69,7 +68,7 @@ var ACTIONS_WITHOUT_ACCESSTOKEN = [
|
|
|
69
68
|
'auth.activateEndUserMail',
|
|
70
69
|
'auth.sendPasswordResetEmail',
|
|
71
70
|
'auth.resetPasswordWithToken',
|
|
72
|
-
'auth.isUsernameRegistered'
|
|
71
|
+
'auth.isUsernameRegistered',
|
|
73
72
|
];
|
|
74
73
|
function bindHooks(instance, name, hooks) {
|
|
75
74
|
var originMethod = instance[name];
|
|
@@ -99,69 +98,30 @@ function beforeEach() {
|
|
|
99
98
|
var seqId = genSeqId();
|
|
100
99
|
return {
|
|
101
100
|
data: {
|
|
102
|
-
seqId: seqId
|
|
101
|
+
seqId: seqId,
|
|
103
102
|
},
|
|
104
103
|
headers: {
|
|
105
|
-
'X-SDK-Version': "@cloudbase/js-sdk/"
|
|
106
|
-
'x-seqid': seqId
|
|
107
|
-
}
|
|
104
|
+
'X-SDK-Version': "@cloudbase/js-sdk/".concat((0, common_1.getSdkVersion)()),
|
|
105
|
+
'x-seqid': seqId,
|
|
106
|
+
},
|
|
108
107
|
};
|
|
109
108
|
}
|
|
110
109
|
var CloudbaseRequest = (function () {
|
|
111
110
|
function CloudbaseRequest(config) {
|
|
112
111
|
this._throwWhenRequestFail = false;
|
|
113
|
-
var _fromApp = config._fromApp;
|
|
114
112
|
this.config = config;
|
|
115
|
-
this._fromApp = _fromApp;
|
|
116
113
|
this._reqClass = new adapter_1.Platform.adapter.reqClass({
|
|
117
114
|
timeout: this.config.timeout,
|
|
118
|
-
timeoutMsg: "[@cloudbase/js-sdk] \u8BF7\u6C42\u5728"
|
|
119
|
-
restrictedMethods: ['post']
|
|
115
|
+
timeoutMsg: "[@cloudbase/js-sdk] \u8BF7\u6C42\u5728".concat(this.config.timeout / 1000, "s\u5185\u672A\u5B8C\u6210\uFF0C\u5DF2\u4E2D\u65AD"),
|
|
116
|
+
restrictedMethods: ['post'],
|
|
120
117
|
});
|
|
121
118
|
this._throwWhenRequestFail = config.throw || false;
|
|
122
|
-
this._cache = cache_1.getCacheByEnvId(this.config.env);
|
|
123
|
-
this._localCache = cache_1.getLocalCache(this.config.env);
|
|
119
|
+
this._cache = (0, cache_1.getCacheByEnvId)(this.config.env);
|
|
120
|
+
this._localCache = (0, cache_1.getLocalCache)(this.config.env);
|
|
124
121
|
bindHooks(this._reqClass, 'post', [beforeEach]);
|
|
125
122
|
bindHooks(this._reqClass, 'upload', [beforeEach]);
|
|
126
123
|
bindHooks(this._reqClass, 'download', [beforeEach]);
|
|
127
124
|
}
|
|
128
|
-
CloudbaseRequest.prototype.fetch = function (urlOrPath, init) {
|
|
129
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
130
|
-
var deviceId, headers, _a, appSign, appSecret, timestamp, appAccessKey, appAccessKeyId, sign, url;
|
|
131
|
-
return __generator(this, function (_b) {
|
|
132
|
-
switch (_b.label) {
|
|
133
|
-
case 0: return [4, this.getDeviceId()];
|
|
134
|
-
case 1:
|
|
135
|
-
deviceId = _b.sent();
|
|
136
|
-
headers = {
|
|
137
|
-
'X-Project-Id': this.config.env,
|
|
138
|
-
'X-SDK-Version': "@cloudbase/js-sdk/" + common_1.getSdkVersion(),
|
|
139
|
-
'X-Request-Id': genSeqId(),
|
|
140
|
-
'X-Request-Timestamp': Date.now(),
|
|
141
|
-
'X-Device-Id': deviceId
|
|
142
|
-
};
|
|
143
|
-
if (adapter_1.Platform.runtime !== RUNTIME.WEB) {
|
|
144
|
-
_a = this.config, appSign = _a.appSign, appSecret = _a.appSecret;
|
|
145
|
-
timestamp = Date.now();
|
|
146
|
-
appAccessKey = appSecret.appAccessKey, appAccessKeyId = appSecret.appAccessKeyId;
|
|
147
|
-
sign = createSign({
|
|
148
|
-
data: {},
|
|
149
|
-
timestamp: timestamp,
|
|
150
|
-
appAccessKeyId: appAccessKeyId,
|
|
151
|
-
appSign: appSign
|
|
152
|
-
}, appAccessKey);
|
|
153
|
-
headers['X-TCB-App-Source'] = "timestamp=" + timestamp + ";appAccessKeyId=" + appAccessKeyId + ";appSign=" + appSign + ";sign=" + sign;
|
|
154
|
-
}
|
|
155
|
-
init.headers = Object.assign({}, init.headers, headers);
|
|
156
|
-
url = urlOrPath.startsWith('http')
|
|
157
|
-
? urlOrPath
|
|
158
|
-
: "" + common_1.getBaseEndPoint() + urlOrPath;
|
|
159
|
-
return [4, fetch(url, init)];
|
|
160
|
-
case 2: return [2, _b.sent()];
|
|
161
|
-
}
|
|
162
|
-
});
|
|
163
|
-
});
|
|
164
|
-
};
|
|
165
125
|
CloudbaseRequest.prototype.post = function (options) {
|
|
166
126
|
return __awaiter(this, void 0, void 0, function () {
|
|
167
127
|
var res;
|
|
@@ -232,176 +192,72 @@ var CloudbaseRequest = (function () {
|
|
|
232
192
|
});
|
|
233
193
|
});
|
|
234
194
|
};
|
|
235
|
-
CloudbaseRequest.prototype.refreshAccessTokenFromOauthServer = function (clientId) {
|
|
236
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
237
|
-
var result, err, e_2;
|
|
238
|
-
return __generator(this, function (_a) {
|
|
239
|
-
switch (_a.label) {
|
|
240
|
-
case 0:
|
|
241
|
-
if (!this._refreshAccessTokenPromise) {
|
|
242
|
-
this._refreshAccessTokenPromise = this._refreshAccessTokenFromOauthServer(clientId);
|
|
243
|
-
}
|
|
244
|
-
_a.label = 1;
|
|
245
|
-
case 1:
|
|
246
|
-
_a.trys.push([1, 3, , 4]);
|
|
247
|
-
return [4, this._refreshAccessTokenPromise];
|
|
248
|
-
case 2:
|
|
249
|
-
result = _a.sent();
|
|
250
|
-
return [3, 4];
|
|
251
|
-
case 3:
|
|
252
|
-
e_2 = _a.sent();
|
|
253
|
-
err = e_2;
|
|
254
|
-
return [3, 4];
|
|
255
|
-
case 4:
|
|
256
|
-
this._refreshAccessTokenPromise = null;
|
|
257
|
-
this._shouldRefreshAccessTokenHook = null;
|
|
258
|
-
if (err) {
|
|
259
|
-
throw err;
|
|
260
|
-
}
|
|
261
|
-
return [2, result];
|
|
262
|
-
}
|
|
263
|
-
});
|
|
264
|
-
});
|
|
265
|
-
};
|
|
266
|
-
CloudbaseRequest.prototype.getOauthAccessToken = function () {
|
|
267
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
268
|
-
var oauthClient;
|
|
269
|
-
return __generator(this, function (_a) {
|
|
270
|
-
oauthClient = this.config.oauthClient;
|
|
271
|
-
if (oauthClient) {
|
|
272
|
-
return [2, this.getOauthAccessTokenV2(oauthClient)];
|
|
273
|
-
}
|
|
274
|
-
return [2];
|
|
275
|
-
});
|
|
276
|
-
});
|
|
277
|
-
};
|
|
278
|
-
CloudbaseRequest.prototype.getOauthAccessTokenV2 = function (oauthClient) {
|
|
279
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
280
|
-
var validAccessToken, credentials;
|
|
281
|
-
return __generator(this, function (_a) {
|
|
282
|
-
switch (_a.label) {
|
|
283
|
-
case 0: return [4, oauthClient.getAccessToken()];
|
|
284
|
-
case 1:
|
|
285
|
-
validAccessToken = _a.sent();
|
|
286
|
-
return [4, oauthClient._getCredentials()];
|
|
287
|
-
case 2:
|
|
288
|
-
credentials = _a.sent();
|
|
289
|
-
return [2, {
|
|
290
|
-
accessToken: validAccessToken,
|
|
291
|
-
accessTokenExpire: new Date(credentials.expires_at).getTime()
|
|
292
|
-
}];
|
|
293
|
-
}
|
|
294
|
-
});
|
|
295
|
-
});
|
|
296
|
-
};
|
|
297
195
|
CloudbaseRequest.prototype.getAccessToken = function () {
|
|
298
196
|
return __awaiter(this, void 0, void 0, function () {
|
|
299
|
-
var _a,
|
|
197
|
+
var _a, accessTokenKey, accessTokenExpireKey, refreshTokenKey, refreshToken, accessToken, accessTokenExpire, _b, shouldRefreshAccessToken, _c;
|
|
300
198
|
return __generator(this, function (_d) {
|
|
301
199
|
switch (_d.label) {
|
|
302
200
|
case 0:
|
|
303
|
-
_a = this._cache.keys,
|
|
304
|
-
return [4, this._cache.getStoreAsync(loginTypeKey)];
|
|
305
|
-
case 1:
|
|
306
|
-
loginType = _d.sent();
|
|
201
|
+
_a = this._cache.keys, accessTokenKey = _a.accessTokenKey, accessTokenExpireKey = _a.accessTokenExpireKey, refreshTokenKey = _a.refreshTokenKey;
|
|
307
202
|
return [4, this._cache.getStoreAsync(refreshTokenKey)];
|
|
308
|
-
case
|
|
203
|
+
case 1:
|
|
309
204
|
refreshToken = _d.sent();
|
|
310
205
|
if (!refreshToken) {
|
|
311
206
|
throw new Error(JSON.stringify({
|
|
312
207
|
code: ERRORS.OPERATION_FAIL,
|
|
313
|
-
msg: 'refresh token is not exist, your local data might be messed up, please retry after clear localStorage or sessionStorage'
|
|
208
|
+
msg: 'refresh token is not exist, your local data might be messed up, please retry after clear localStorage or sessionStorage',
|
|
314
209
|
}));
|
|
315
210
|
}
|
|
316
211
|
return [4, this._cache.getStoreAsync(accessTokenKey)];
|
|
317
|
-
case
|
|
212
|
+
case 2:
|
|
318
213
|
accessToken = _d.sent();
|
|
319
214
|
_b = Number;
|
|
320
215
|
return [4, this._cache.getStoreAsync(accessTokenExpireKey)];
|
|
321
|
-
case
|
|
216
|
+
case 3:
|
|
322
217
|
accessTokenExpire = _b.apply(void 0, [_d.sent()]);
|
|
323
218
|
shouldRefreshAccessToken = true;
|
|
324
219
|
_c = this._shouldRefreshAccessTokenHook;
|
|
325
|
-
if (!_c) return [3,
|
|
220
|
+
if (!_c) return [3, 5];
|
|
326
221
|
return [4, this._shouldRefreshAccessTokenHook(accessToken, accessTokenExpire)];
|
|
327
|
-
case
|
|
222
|
+
case 4:
|
|
328
223
|
_c = !(_d.sent());
|
|
329
|
-
_d.label =
|
|
330
|
-
case
|
|
224
|
+
_d.label = 5;
|
|
225
|
+
case 5:
|
|
331
226
|
if (_c) {
|
|
332
227
|
shouldRefreshAccessToken = false;
|
|
333
228
|
}
|
|
334
|
-
if (!((!accessToken || !accessTokenExpire || accessTokenExpire < Date.now()) && shouldRefreshAccessToken)) return [3,
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
payload = null;
|
|
339
|
-
try {
|
|
340
|
-
header = utilities_1.jwt.decode(accessToken, { header: true });
|
|
341
|
-
payload = utilities_1.jwt.decode(accessToken);
|
|
342
|
-
}
|
|
343
|
-
catch (e) {
|
|
344
|
-
throw new Error("[DECODE_ACCESS_TOKEN_ERROR] " + e.message + ", accesstoken: " + accessToken);
|
|
345
|
-
}
|
|
346
|
-
if (!((header === null || header === void 0 ? void 0 : header.kid) && (payload === null || payload === void 0 ? void 0 : payload.project_id))) return [3, 8];
|
|
347
|
-
return [4, this.refreshAccessTokenFromOauthServer(payload === null || payload === void 0 ? void 0 : payload.project_id)];
|
|
348
|
-
case 7: return [2, _d.sent()];
|
|
349
|
-
case 8: return [3, 11];
|
|
350
|
-
case 9: return [4, this.refreshAccessTokenFromOauthServer(this.config.env)];
|
|
351
|
-
case 10: return [2, _d.sent()];
|
|
352
|
-
case 11: return [3, 14];
|
|
353
|
-
case 12: return [4, this.refreshAccessToken()];
|
|
354
|
-
case 13: return [2, _d.sent()];
|
|
355
|
-
case 14: return [3, 16];
|
|
356
|
-
case 15: return [2, {
|
|
229
|
+
if (!((!accessToken || !accessTokenExpire || accessTokenExpire < Date.now()) && shouldRefreshAccessToken)) return [3, 7];
|
|
230
|
+
return [4, this.refreshAccessToken()];
|
|
231
|
+
case 6: return [2, _d.sent()];
|
|
232
|
+
case 7: return [2, {
|
|
357
233
|
accessToken: accessToken,
|
|
358
|
-
accessTokenExpire: accessTokenExpire
|
|
234
|
+
accessTokenExpire: accessTokenExpire,
|
|
359
235
|
}];
|
|
360
|
-
case 16: return [2];
|
|
361
236
|
}
|
|
362
237
|
});
|
|
363
238
|
});
|
|
364
239
|
};
|
|
365
240
|
CloudbaseRequest.prototype.request = function (action, params, options) {
|
|
366
241
|
return __awaiter(this, void 0, void 0, function () {
|
|
367
|
-
var
|
|
368
|
-
return __generator(this, function (
|
|
369
|
-
switch (
|
|
242
|
+
var tcbTraceKey, contentType, tmpObj, refreshTokenKey, refreshToken, _a, payload, key, key, opts, traceHeader, _b, appSign, appSecret, timestamp, appAccessKey, appAccessKeyId, sign, parse, inQuery, search, formatQuery, _c, BASE_URL, PROTOCOL, newUrl, res, resTraceHeader;
|
|
243
|
+
return __generator(this, function (_d) {
|
|
244
|
+
switch (_d.label) {
|
|
370
245
|
case 0:
|
|
371
|
-
|
|
372
|
-
tcbTraceKey = "x-tcb-trace_" + this.config.env;
|
|
246
|
+
tcbTraceKey = "x-tcb-trace_".concat(this.config.env);
|
|
373
247
|
contentType = 'application/x-www-form-urlencoded';
|
|
374
248
|
tmpObj = __assign({ action: action, dataVersion: common_1.DATA_VERSION, env: this.config.env }, params);
|
|
375
|
-
if (!
|
|
376
|
-
_a = tmpObj;
|
|
377
|
-
return [4, this.getOauthAccessToken()];
|
|
378
|
-
case 1:
|
|
379
|
-
_a.access_token = (_f.sent()).accessToken;
|
|
380
|
-
return [3, 5];
|
|
381
|
-
case 2: return [4, this.checkFromAuthV2()];
|
|
382
|
-
case 3:
|
|
383
|
-
loginFlag = _f.sent();
|
|
384
|
-
if (!(loginFlag === 'oauth')) return [3, 5];
|
|
385
|
-
app = this.config._fromApp;
|
|
386
|
-
oauthClient_1 = app.oauthInstance.oauth2client;
|
|
387
|
-
_b = tmpObj;
|
|
388
|
-
return [4, this.getOauthAccessTokenV2(oauthClient_1)];
|
|
389
|
-
case 4:
|
|
390
|
-
_b.access_token = (_f.sent()).accessToken;
|
|
391
|
-
_f.label = 5;
|
|
392
|
-
case 5:
|
|
393
|
-
if (!(ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1)) return [3, 8];
|
|
249
|
+
if (!(ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1)) return [3, 3];
|
|
394
250
|
refreshTokenKey = this._cache.keys.refreshTokenKey;
|
|
395
251
|
return [4, this._cache.getStoreAsync(refreshTokenKey)];
|
|
396
|
-
case
|
|
397
|
-
refreshToken =
|
|
398
|
-
if (!refreshToken) return [3,
|
|
399
|
-
|
|
252
|
+
case 1:
|
|
253
|
+
refreshToken = _d.sent();
|
|
254
|
+
if (!refreshToken) return [3, 3];
|
|
255
|
+
_a = tmpObj;
|
|
400
256
|
return [4, this.getAccessToken()];
|
|
401
|
-
case
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
case
|
|
257
|
+
case 2:
|
|
258
|
+
_a.access_token = (_d.sent()).accessToken;
|
|
259
|
+
_d.label = 3;
|
|
260
|
+
case 3:
|
|
405
261
|
if (action === 'storage.uploadFile') {
|
|
406
262
|
payload = new FormData();
|
|
407
263
|
for (key in payload) {
|
|
@@ -422,11 +278,11 @@ var CloudbaseRequest = (function () {
|
|
|
422
278
|
}
|
|
423
279
|
opts = {
|
|
424
280
|
headers: {
|
|
425
|
-
'content-type': contentType
|
|
426
|
-
}
|
|
281
|
+
'content-type': contentType,
|
|
282
|
+
},
|
|
427
283
|
};
|
|
428
|
-
if (options === null || options === void 0 ? void 0 : options
|
|
429
|
-
opts.onUploadProgress = options
|
|
284
|
+
if (options === null || options === void 0 ? void 0 : options.onUploadProgress) {
|
|
285
|
+
opts.onUploadProgress = options.onUploadProgress;
|
|
430
286
|
}
|
|
431
287
|
if (this.config.region) {
|
|
432
288
|
opts.headers['X-TCB-Region'] = this.config.region;
|
|
@@ -436,31 +292,31 @@ var CloudbaseRequest = (function () {
|
|
|
436
292
|
opts.headers['X-TCB-Trace'] = traceHeader;
|
|
437
293
|
}
|
|
438
294
|
if (adapter_1.Platform.runtime !== RUNTIME.WEB) {
|
|
439
|
-
|
|
295
|
+
_b = this.config, appSign = _b.appSign, appSecret = _b.appSecret;
|
|
440
296
|
timestamp = Date.now();
|
|
441
297
|
appAccessKey = appSecret.appAccessKey, appAccessKeyId = appSecret.appAccessKeyId;
|
|
442
298
|
sign = createSign({
|
|
443
299
|
data: {},
|
|
444
300
|
timestamp: timestamp,
|
|
445
301
|
appAccessKeyId: appAccessKeyId,
|
|
446
|
-
appSign: appSign
|
|
302
|
+
appSign: appSign,
|
|
447
303
|
}, appAccessKey);
|
|
448
|
-
opts.headers['X-TCB-App-Source'] = "timestamp="
|
|
304
|
+
opts.headers['X-TCB-App-Source'] = "timestamp=".concat(timestamp, ";appAccessKeyId=").concat(appAccessKeyId, ";appSign=").concat(appSign, ";sign=").concat(sign);
|
|
449
305
|
}
|
|
450
306
|
parse = params.parse, inQuery = params.inQuery, search = params.search;
|
|
451
307
|
formatQuery = {
|
|
452
|
-
env: this.config.env
|
|
308
|
+
env: this.config.env,
|
|
453
309
|
};
|
|
454
310
|
parse && (formatQuery.parse = true);
|
|
455
311
|
inQuery && (formatQuery = __assign(__assign({}, inQuery), formatQuery));
|
|
456
|
-
|
|
312
|
+
_c = (0, common_1.getEndPoint)(), BASE_URL = _c.BASE_URL, PROTOCOL = _c.PROTOCOL;
|
|
457
313
|
newUrl = formatUrl(PROTOCOL, BASE_URL, formatQuery);
|
|
458
314
|
if (search) {
|
|
459
315
|
newUrl += search;
|
|
460
316
|
}
|
|
461
317
|
return [4, this.post(__assign({ url: newUrl, data: payload }, opts))];
|
|
462
|
-
case
|
|
463
|
-
res =
|
|
318
|
+
case 4:
|
|
319
|
+
res = _d.sent();
|
|
464
320
|
resTraceHeader = res.header && res.header['x-tcb-trace'];
|
|
465
321
|
if (resTraceHeader) {
|
|
466
322
|
this._localCache.setStore(tcbTraceKey, resTraceHeader);
|
|
@@ -494,7 +350,7 @@ var CloudbaseRequest = (function () {
|
|
|
494
350
|
if (response.data.code && this._throwWhenRequestFail) {
|
|
495
351
|
throw new Error(JSON.stringify({
|
|
496
352
|
code: ERRORS.OPERATION_FAIL,
|
|
497
|
-
msg: "["
|
|
353
|
+
msg: "[".concat(response.data.code, "] ").concat(response.data.message),
|
|
498
354
|
}));
|
|
499
355
|
}
|
|
500
356
|
return [2, response.data];
|
|
@@ -522,11 +378,11 @@ var CloudbaseRequest = (function () {
|
|
|
522
378
|
if (!refreshToken) {
|
|
523
379
|
throw new Error(JSON.stringify({
|
|
524
380
|
code: ERRORS.INVALID_OPERATION,
|
|
525
|
-
msg: 'not login'
|
|
381
|
+
msg: 'not login',
|
|
526
382
|
}));
|
|
527
383
|
}
|
|
528
384
|
params = {
|
|
529
|
-
refresh_token: refreshToken
|
|
385
|
+
refresh_token: refreshToken,
|
|
530
386
|
};
|
|
531
387
|
return [4, this.request('auth.fetchAccessTokenWithRefreshToken', params)];
|
|
532
388
|
case 4:
|
|
@@ -546,7 +402,7 @@ var CloudbaseRequest = (function () {
|
|
|
546
402
|
refresh_token = _b.sent();
|
|
547
403
|
return [4, this.send('auth.signInAnonymously', {
|
|
548
404
|
anonymous_uuid: anonymous_uuid,
|
|
549
|
-
refresh_token: refresh_token
|
|
405
|
+
refresh_token: refresh_token,
|
|
550
406
|
})];
|
|
551
407
|
case 8:
|
|
552
408
|
res = _b.sent();
|
|
@@ -554,13 +410,10 @@ var CloudbaseRequest = (function () {
|
|
|
554
410
|
if (retryNum >= 1) {
|
|
555
411
|
return [2, this._refreshAccessToken(--retryNum)];
|
|
556
412
|
}
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
}));
|
|
562
|
-
}
|
|
563
|
-
_b.label = 9;
|
|
413
|
+
throw new Error(JSON.stringify({
|
|
414
|
+
code: ERRORS.OPERATION_FAIL,
|
|
415
|
+
message: '重试获取 refresh token 失败',
|
|
416
|
+
}));
|
|
564
417
|
case 9:
|
|
565
418
|
__1.cloudbase.fire(events_1.EVENTS.LOGIN_STATE_EXPIRED);
|
|
566
419
|
return [4, this._cache.removeStoreAsync(refreshTokenKey)];
|
|
@@ -569,7 +422,7 @@ var CloudbaseRequest = (function () {
|
|
|
569
422
|
_b.label = 11;
|
|
570
423
|
case 11: throw new Error(JSON.stringify({
|
|
571
424
|
code: ERRORS.NETWORK_ERROR,
|
|
572
|
-
msg: "refresh access_token failed\uFF1A"
|
|
425
|
+
msg: "refresh access_token failed\uFF1A".concat(response.data.code),
|
|
573
426
|
}));
|
|
574
427
|
case 12:
|
|
575
428
|
if (!response.data.access_token) return [3, 15];
|
|
@@ -582,7 +435,7 @@ var CloudbaseRequest = (function () {
|
|
|
582
435
|
_b.sent();
|
|
583
436
|
return [2, {
|
|
584
437
|
accessToken: response.data.access_token,
|
|
585
|
-
accessTokenExpire: response.data.access_token_expire
|
|
438
|
+
accessTokenExpire: response.data.access_token_expire,
|
|
586
439
|
}];
|
|
587
440
|
case 15:
|
|
588
441
|
if (!response.data.refresh_token) return [3, 19];
|
|
@@ -601,92 +454,6 @@ var CloudbaseRequest = (function () {
|
|
|
601
454
|
});
|
|
602
455
|
});
|
|
603
456
|
};
|
|
604
|
-
CloudbaseRequest.prototype._fetchAccessTokenFromOauthServer = function (refreshToken, clientId) {
|
|
605
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
606
|
-
var resp, seqIdFromHeader, body, seqId, body, seqId;
|
|
607
|
-
return __generator(this, function (_a) {
|
|
608
|
-
switch (_a.label) {
|
|
609
|
-
case 0: return [4, this.fetch('/auth/v1/token', {
|
|
610
|
-
method: 'POST',
|
|
611
|
-
headers: {
|
|
612
|
-
'Accept': 'application/json',
|
|
613
|
-
'Content-Type': 'application/json'
|
|
614
|
-
},
|
|
615
|
-
body: JSON.stringify({
|
|
616
|
-
grant_type: 'refresh_token',
|
|
617
|
-
client_id: clientId,
|
|
618
|
-
refresh_token: refreshToken
|
|
619
|
-
})
|
|
620
|
-
})];
|
|
621
|
-
case 1:
|
|
622
|
-
resp = _a.sent();
|
|
623
|
-
seqIdFromHeader = resp.headers.get('SeqId') || resp.headers.get('RequestId');
|
|
624
|
-
if (!(resp.status >= 400 && resp.status < 500)) return [3, 3];
|
|
625
|
-
return [4, resp.json()];
|
|
626
|
-
case 2:
|
|
627
|
-
body = _a.sent();
|
|
628
|
-
seqId = body.request_id || seqIdFromHeader;
|
|
629
|
-
throw new Error("[" + getSdkName() + "/" + common_1.getSdkVersion() + "][OAuth2AuthProvider][status:" + resp.status + "][" + body.error + "(" + body.error_code + ")] " + body.error_description + " (" + seqId + ")");
|
|
630
|
-
case 3:
|
|
631
|
-
if (!(resp.status >= 500)) return [3, 5];
|
|
632
|
-
return [4, resp.json()];
|
|
633
|
-
case 4:
|
|
634
|
-
body = _a.sent();
|
|
635
|
-
seqId = body.request_id || seqIdFromHeader;
|
|
636
|
-
throw new Error("[" + getSdkName() + "/" + common_1.getSdkVersion() + "][OAuth2AuthProvider][status:" + resp.status + "][" + body.error + "(" + body.error_code + ")] " + body.error_description + " (" + seqId + ")");
|
|
637
|
-
case 5: return [2, resp.json()];
|
|
638
|
-
}
|
|
639
|
-
});
|
|
640
|
-
});
|
|
641
|
-
};
|
|
642
|
-
CloudbaseRequest.prototype._refreshAccessTokenFromOauthServer = function (clientId) {
|
|
643
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
644
|
-
var _a, accessTokenKey, accessTokenExpireKey, refreshTokenKey, refreshToken, token, newRefreshToken, accessToken, accessTokenExpire;
|
|
645
|
-
return __generator(this, function (_b) {
|
|
646
|
-
switch (_b.label) {
|
|
647
|
-
case 0:
|
|
648
|
-
_a = this._cache.keys, accessTokenKey = _a.accessTokenKey, accessTokenExpireKey = _a.accessTokenExpireKey, refreshTokenKey = _a.refreshTokenKey;
|
|
649
|
-
return [4, this._cache.getStoreAsync(refreshTokenKey)];
|
|
650
|
-
case 1:
|
|
651
|
-
refreshToken = _b.sent();
|
|
652
|
-
if (!refreshToken) {
|
|
653
|
-
throw new Error(JSON.stringify({
|
|
654
|
-
code: ERRORS.INVALID_OPERATION,
|
|
655
|
-
msg: 'not login'
|
|
656
|
-
}));
|
|
657
|
-
}
|
|
658
|
-
return [4, this._fetchAccessTokenFromOauthServer(refreshToken, clientId)];
|
|
659
|
-
case 2:
|
|
660
|
-
token = _b.sent();
|
|
661
|
-
newRefreshToken = token.refresh_token, accessToken = token.access_token, accessTokenExpire = token.expires_in;
|
|
662
|
-
if (!accessToken || !accessTokenExpire) {
|
|
663
|
-
throw new Error(JSON.stringify({
|
|
664
|
-
code: ERRORS.NETWORK_ERROR,
|
|
665
|
-
msg: 'refresh access_token failed'
|
|
666
|
-
}));
|
|
667
|
-
}
|
|
668
|
-
if (!(accessToken && accessTokenExpire)) return [3, 7];
|
|
669
|
-
if (!(newRefreshToken === refreshToken)) return [3, 4];
|
|
670
|
-
return [4, this._cache.setStoreAsync(refreshTokenKey, newRefreshToken)];
|
|
671
|
-
case 3:
|
|
672
|
-
_b.sent();
|
|
673
|
-
_b.label = 4;
|
|
674
|
-
case 4: return [4, this._cache.setStoreAsync(accessTokenKey, accessToken)];
|
|
675
|
-
case 5:
|
|
676
|
-
_b.sent();
|
|
677
|
-
return [4, this._cache.setStoreAsync(accessTokenExpireKey, accessTokenExpire * 1000 + Date.now())];
|
|
678
|
-
case 6:
|
|
679
|
-
_b.sent();
|
|
680
|
-
__1.cloudbase.fire(events_1.EVENTS.ACCESS_TOKEN_REFRESHD);
|
|
681
|
-
return [2, {
|
|
682
|
-
accessToken: accessToken,
|
|
683
|
-
accessTokenExpire: accessTokenExpire
|
|
684
|
-
}];
|
|
685
|
-
case 7: return [2];
|
|
686
|
-
}
|
|
687
|
-
});
|
|
688
|
-
});
|
|
689
|
-
};
|
|
690
457
|
CloudbaseRequest.prototype._setRefreshToken = function (refreshToken) {
|
|
691
458
|
return __awaiter(this, void 0, void 0, function () {
|
|
692
459
|
var _a, accessTokenKey, accessTokenExpireKey, refreshTokenKey;
|
|
@@ -708,52 +475,6 @@ var CloudbaseRequest = (function () {
|
|
|
708
475
|
});
|
|
709
476
|
});
|
|
710
477
|
};
|
|
711
|
-
CloudbaseRequest.prototype.getDeviceId = function () {
|
|
712
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
713
|
-
var deviceIdKey, deviceId, newDeviceId;
|
|
714
|
-
return __generator(this, function (_a) {
|
|
715
|
-
switch (_a.label) {
|
|
716
|
-
case 0:
|
|
717
|
-
deviceIdKey = this._cache.keys.deviceIdKey;
|
|
718
|
-
return [4, this._cache.getStoreAsync(deviceIdKey)];
|
|
719
|
-
case 1:
|
|
720
|
-
deviceId = _a.sent();
|
|
721
|
-
if (!deviceId) {
|
|
722
|
-
newDeviceId = uuid_1.v4();
|
|
723
|
-
this._cache.setStoreAsync(deviceIdKey, newDeviceId);
|
|
724
|
-
return [2, newDeviceId];
|
|
725
|
-
}
|
|
726
|
-
else {
|
|
727
|
-
return [2, deviceId];
|
|
728
|
-
}
|
|
729
|
-
return [2];
|
|
730
|
-
}
|
|
731
|
-
});
|
|
732
|
-
});
|
|
733
|
-
};
|
|
734
|
-
CloudbaseRequest.prototype.checkFromAuthV2 = function () {
|
|
735
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
736
|
-
var oauthInstance, oauthLogin, _a;
|
|
737
|
-
return __generator(this, function (_b) {
|
|
738
|
-
switch (_b.label) {
|
|
739
|
-
case 0:
|
|
740
|
-
oauthInstance = this._fromApp.oauthInstance || this._fromApp.oauth();
|
|
741
|
-
_a = oauthInstance;
|
|
742
|
-
if (!_a) return [3, 2];
|
|
743
|
-
return [4, oauthInstance.hasLoginState()];
|
|
744
|
-
case 1:
|
|
745
|
-
_a = (_b.sent());
|
|
746
|
-
_b.label = 2;
|
|
747
|
-
case 2:
|
|
748
|
-
oauthLogin = _a;
|
|
749
|
-
if (oauthLogin) {
|
|
750
|
-
return [2, 'oauth'];
|
|
751
|
-
}
|
|
752
|
-
return [2, ''];
|
|
753
|
-
}
|
|
754
|
-
});
|
|
755
|
-
});
|
|
756
|
-
};
|
|
757
478
|
return CloudbaseRequest;
|
|
758
479
|
}());
|
|
759
480
|
exports.CloudbaseRequest = CloudbaseRequest;
|
|
@@ -766,4 +487,4 @@ function getRequestByEnvId(env) {
|
|
|
766
487
|
return requestMap[env];
|
|
767
488
|
}
|
|
768
489
|
exports.getRequestByEnvId = getRequestByEnvId;
|
|
769
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request.js","sourceRoot":"","sources":["../../../src/libs/request.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  DATA_VERSION,\n  LOGINTYPE,\n  getSdkVersion,\n  getEndPoint,\n  getBaseEndPoint,\n  OAUTH2_LOGINTYPE_PREFIX\n} from '../constants/common';\nimport {\n  IRequestOptions,\n  SDKRequestInterface,\n  ResponseObject,\n  IUploadRequestOptions,\n  IRequestConfig\n} from '@cloudbase/adapter-interface';\nimport { utils, jwt, adapters, constants } from '@cloudbase/utilities';\nimport { KV, ICloudbase } from '@cloudbase/types';\nimport { IGetAccessTokenResult, ICloudbaseRequestConfig, IAppendedRequestInfo, IRequestBeforeHook } from '@cloudbase/types/request';\nimport { ICloudbaseCache } from '@cloudbase/types/cache';\nimport { cloudbase } from '..';\nimport { getCacheByEnvId, getLocalCache } from './cache';\nimport { EVENTS } from '../constants/events';\nimport { Platform } from './adapter';\nconst { getSdkName, ERRORS } = constants;\nconst { genSeqId, isFormData, formatUrl, createSign } = utils;\nconst { RUNTIME } = adapters;\n\nimport { v4 as uuidv4 } from 'uuid'\n\n// import FingerprintJS from '@fingerprintjs/fingerprintjs'\n// const fpPromise = FingerprintJS.load()\n\n// 下面几种 action 不需要 access token\nconst ACTIONS_WITHOUT_ACCESSTOKEN = [\n  'auth.getJwt',\n  'auth.logout',\n  'auth.signInWithTicket',\n  'auth.signInAnonymously',\n  'auth.signIn',\n  'auth.fetchAccessTokenWithRefreshToken',\n  'auth.signUpWithEmailAndPassword',\n  'auth.activateEndUserMail',\n  'auth.sendPasswordResetEmail',\n  'auth.resetPasswordWithToken',\n  'auth.isUsernameRegistered'\n];\n\nfunction bindHooks(instance: SDKRequestInterface, name: string, hooks: IRequestBeforeHook[]) {\n  const originMethod = instance[name];\n  instance[name] = function (options: IRequestOptions) {\n    const data = {};\n    const headers = {};\n    hooks.forEach(hook => {\n      const { data: appendedData, headers: appendedHeaders } = hook.call(instance, options);\n      Object.assign(data, appendedData);\n      Object.assign(headers, appendedHeaders);\n    });\n    const originData = options.data;\n    originData && (() => {\n      if (isFormData(originData)) {\n        for (const key in data) {\n          (originData as FormData).append(key, data[key]);\n        }\n        return;\n      }\n      options.data = {\n        ...originData,\n        ...data\n      };\n    })();\n    options.headers = {\n      ...(options.headers || {}),\n      ...headers\n    };\n    return (originMethod as Function).call(instance, options);\n  };\n}\nfunction beforeEach(): IAppendedRequestInfo {\n  const seqId = genSeqId();\n  return {\n    data: {\n      seqId\n    },\n    headers: {\n      'X-SDK-Version': `@cloudbase/js-sdk/${getSdkVersion()}`,\n      'x-seqid': seqId\n    }\n  };\n}\nexport interface ICloudbaseRequest {\n  fetch: (urlOrPath: string, init?: RequestInit) => Promise<Response>;\n  post: (options: IRequestOptions) => Promise<ResponseObject>;\n  upload: (options: IUploadRequestOptions) => Promise<ResponseObject>;\n  download: (options: IRequestOptions) => Promise<ResponseObject>;\n  refreshAccessToken: () => Promise<IGetAccessTokenResult>;\n  getAccessToken: () => Promise<IGetAccessTokenResult>;\n  request: (action: string, params: KV<any>, options?: KV<any>) => Promise<ResponseObject>;\n  send: (action: string, data: KV<any>) => Promise<any>;\n}\n\n/**\n * @class CloudbaseRequest\n */\nexport class CloudbaseRequest implements ICloudbaseRequest {\n  config: ICloudbaseRequestConfig;\n  _shouldRefreshAccessTokenHook: Function\n  _refreshAccessTokenPromise: Promise<IGetAccessTokenResult> | null\n  _reqClass: SDKRequestInterface;\n  // 请求失败是否抛出Error\n  private _throwWhenRequestFail = false;\n  private _cache: ICloudbaseCache;\n  // 持久化本地存储\n  private _localCache: ICloudbaseCache;\n  private _fromApp: ICloudbase\n  /**\n   * 初始化\n   * @param config\n   */\n  constructor(config: ICloudbaseRequestConfig & { throw?: boolean }) {\n    const { _fromApp } = config;\n\n    this.config = config;\n    this._fromApp = _fromApp\n    // eslint-disable-next-line\n    this._reqClass = new Platform.adapter.reqClass(<IRequestConfig>{\n      timeout: this.config.timeout,\n      timeoutMsg: `[@cloudbase/js-sdk] 请求在${this.config.timeout / 1000}s内未完成，已中断`,\n      restrictedMethods: ['post']\n    });\n    this._throwWhenRequestFail = config.throw || false;\n    this._cache = getCacheByEnvId(this.config.env);\n    this._localCache = getLocalCache(this.config.env);\n    bindHooks(this._reqClass, 'post', [beforeEach]);\n    bindHooks(this._reqClass, 'upload', [beforeEach]);\n    bindHooks(this._reqClass, 'download', [beforeEach]);\n  }\n\n  /**\n   * 套一层 fetch，方便处理请求地址\n   * @param {string}      urlOrPath\n   * @param {RequestInit} init\n   * @returns\n   */\n  public async fetch(urlOrPath: string, init?: RequestInit): Promise<Response> {\n    const deviceId = await this.getDeviceId();\n\n    const headers = {\n      'X-Project-Id': this.config.env,\n      'X-SDK-Version': `@cloudbase/js-sdk/${getSdkVersion()}`,\n      'X-Request-Id': genSeqId(),\n      'X-Request-Timestamp': Date.now(),\n      'X-Device-Id': deviceId\n    }\n    // 非web平台使用凭证检验有效性\n    if (Platform.runtime !== RUNTIME.WEB) {\n      const { appSign, appSecret } = this.config\n      const timestamp = Date.now()\n      const { appAccessKey, appAccessKeyId } = appSecret\n      const sign = createSign({\n        // data: init.body,\n        data: {},\n        timestamp,\n        appAccessKeyId,\n        appSign\n      }, appAccessKey)\n\n      headers['X-TCB-App-Source'] = `timestamp=${timestamp};appAccessKeyId=${appAccessKeyId};appSign=${appSign};sign=${sign}`\n    }\n\n    init.headers = Object.assign({}, init.headers, headers)\n\n    const url = urlOrPath.startsWith('http')\n      ? urlOrPath\n      : `${getBaseEndPoint()}${urlOrPath}`\n    return await fetch(url, init)\n  }\n\n  public async post(options: IRequestOptions): Promise<ResponseObject> {\n    const res = await this._reqClass.post(options);\n    return res;\n  }\n  public async upload(options: IUploadRequestOptions): Promise<ResponseObject> {\n    const res = await this._reqClass.upload(options);\n    return res;\n  }\n  public async download(options: IRequestOptions): Promise<ResponseObject> {\n    const res = await this._reqClass.download(options);\n    return res;\n  }\n\n  public async refreshAccessToken(): Promise<IGetAccessTokenResult> {\n    // 可能会同时调用多次刷新access token，这里把它们合并成一个\n    if (!this._refreshAccessTokenPromise) {\n      // 没有正在刷新，那么正常执行刷新逻辑\n      this._refreshAccessTokenPromise = this._refreshAccessToken();\n    }\n\n    let result;\n    let err;\n    try {\n      result = await this._refreshAccessTokenPromise;\n    } catch (e) {\n      err = e;\n    }\n    this._refreshAccessTokenPromise = null;\n    this._shouldRefreshAccessTokenHook = null;\n    if (err) {\n      throw err;\n    }\n    return result;\n  }\n\n  public async refreshAccessTokenFromOauthServer(clientId: string): Promise<IGetAccessTokenResult> {\n    // 可能会同时调用多次刷新 access token，这里把它们合并成一个\n    if (!this._refreshAccessTokenPromise) {\n      // 没有正在刷新，那么正常执行刷新逻辑\n      this._refreshAccessTokenPromise = this._refreshAccessTokenFromOauthServer(clientId);\n    }\n\n    let result;\n    let err;\n    try {\n      result = await this._refreshAccessTokenPromise;\n    } catch (e) {\n      err = e;\n    }\n    this._refreshAccessTokenPromise = null;\n    this._shouldRefreshAccessTokenHook = null;\n    if (err) {\n      throw err;\n    }\n    return result;\n  }\n\n  // 获取 OAuth accesstoken\n  public async getOauthAccessToken(): Promise<IGetAccessTokenResult> {\n    const { oauthClient } = this.config\n    if (oauthClient) {\n      // const validAccessToken = await oauthClient.getAccessToken()\n      // const credentials = await oauthClient._getCredentials()\n      // return {\n      //   accessToken: validAccessToken,\n      //   accessTokenExpire: new Date(credentials.expires_at).getTime()\n      // }\n      return this.getOauthAccessTokenV2(oauthClient)\n    }\n  }\n\n  public async getOauthAccessTokenV2(oauthClient: any): Promise<IGetAccessTokenResult> {\n    const validAccessToken = await oauthClient.getAccessToken()\n    const credentials = await oauthClient._getCredentials()\n    return {\n      accessToken: validAccessToken,\n      accessTokenExpire: new Date(credentials.expires_at).getTime()\n    }\n  }\n\n  // 获取 access token\n  public async getAccessToken(): Promise<IGetAccessTokenResult> {\n    const { loginTypeKey, accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys;\n    const loginType = await this._cache.getStoreAsync(loginTypeKey);\n    const refreshToken = await this._cache.getStoreAsync(refreshTokenKey);\n    if (!refreshToken) {\n      // 不该出现的状态：有 access token 却没有 refresh token\n      throw new Error(JSON.stringify({\n        code: ERRORS.OPERATION_FAIL,\n        msg: 'refresh token is not exist, your local data might be messed up, please retry after clear localStorage or sessionStorage'\n      }));\n    }\n    // 如果没有access token或者过期，那么刷新\n    const accessToken = await this._cache.getStoreAsync(accessTokenKey);\n    const accessTokenExpire = Number(await this._cache.getStoreAsync(accessTokenExpireKey));\n\n    // 调用钩子函数\n    let shouldRefreshAccessToken = true;\n    if (this._shouldRefreshAccessTokenHook && !(await this._shouldRefreshAccessTokenHook(accessToken, accessTokenExpire))) {\n      shouldRefreshAccessToken = false;\n    }\n\n    if ((!accessToken || !accessTokenExpire || accessTokenExpire < Date.now()) && shouldRefreshAccessToken) {\n      if (loginType.startsWith(OAUTH2_LOGINTYPE_PREFIX)) {\n        // NOTE: 这里需要从 accessToken 解出来部分信息，用于刷新 accessToken\n        // 所以过期的 accessToken 不能删除，而是用新 accessToken 覆盖\n        if (accessToken) {\n          let header = null\n          let payload = null\n          try {\n            header = jwt.decode(accessToken, { header: true })\n            payload = jwt.decode(accessToken)\n          }\n          catch (e) {\n            throw new Error(`[DECODE_ACCESS_TOKEN_ERROR] ${e.message}, accesstoken: ${accessToken}`)\n          }\n          if (header?.kid && payload?.project_id) {\n            return await this.refreshAccessTokenFromOauthServer(payload?.project_id)\n          }\n        }\n        else {\n          // 这里用 env 试一下\n          return await this.refreshAccessTokenFromOauthServer(this.config.env)\n        }\n      }\n      else {\n        return await this.refreshAccessToken();\n      }\n    } else {\n      // 返回本地的access token\n      return {\n        accessToken,\n        accessTokenExpire\n      };\n    }\n  }\n\n  /* eslint-disable complexity */\n  public async request(action: string, params: KV<any>, options?: KV<any>): Promise<ResponseObject> {\n    const { oauthClient } = this.config\n    const tcbTraceKey = `x-tcb-trace_${this.config.env}`;\n    let contentType = 'application/x-www-form-urlencoded';\n    // const webDeviceId = await getTcbFingerprintId();\n    const tmpObj: KV<any> = {\n      action,\n      // webDeviceId,\n      dataVersion: DATA_VERSION,\n      env: this.config.env,\n      ...params\n    };\n\n    // 若识别到注册了 Oauth 模块，则使用oauth getAccessToken\n    if (oauthClient) {\n      tmpObj.access_token = (await this.getOauthAccessToken()).accessToken\n    } else {\n      // 识别当前登录态 是否为 oauth\n      const loginFlag = await this.checkFromAuthV2()\n      // console.log('loginFlag', loginFlag)\n      if (loginFlag === 'oauth') {\n        const app = this.config._fromApp\n        const oauthClient = app.oauthInstance.oauth2client\n        tmpObj.access_token = (await this.getOauthAccessTokenV2(oauthClient)).accessToken\n      }\n    }\n\n    if (ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1) {\n      const { refreshTokenKey } = this._cache.keys;\n\n      // 若有 refreshToken 则任务有登录态 刷 accessToken\n      const refreshToken = await this._cache.getStoreAsync(refreshTokenKey);\n      if (refreshToken) {\n        tmpObj.access_token = (await this.getAccessToken()).accessToken;\n      }\n    }\n\n    // 拼body和content-type\n    let payload;\n    if (action === 'storage.uploadFile') {\n      payload = new FormData();\n      for (let key in payload) {\n        if (payload.hasOwnProperty(key) && payload[key] !== undefined) {\n          payload.append(key, tmpObj[key]);\n        }\n      }\n      contentType = 'multipart/form-data';\n    } else {\n      contentType = 'application/json;charset=UTF-8';\n      payload = {};\n      for (let key in tmpObj) {\n        if (tmpObj[key] !== undefined) {\n          payload[key] = tmpObj[key];\n        }\n      }\n    }\n    let opts: any = {\n      headers: {\n        'content-type': contentType\n      }\n    };\n    if (options?.['onUploadProgress']) {\n      opts.onUploadProgress = options['onUploadProgress'];\n    }\n\n    if (this.config.region) {\n      opts.headers['X-TCB-Region'] = this.config.region;\n    }\n\n    const traceHeader = this._localCache.getStore(tcbTraceKey);\n    if (traceHeader) {\n      opts.headers['X-TCB-Trace'] = traceHeader;\n    }\n    // 非web平台使用凭证检验有效性\n    if (Platform.runtime !== RUNTIME.WEB) {\n      const { appSign, appSecret } = this.config;\n      const timestamp = Date.now();\n      const { appAccessKey, appAccessKeyId } = appSecret;\n      const sign = createSign({\n        data: {}, // 校验签名流程实际未用到，可设空\n        timestamp,\n        appAccessKeyId,\n        appSign\n      }, appAccessKey);\n\n      opts.headers['X-TCB-App-Source'] = `timestamp=${timestamp};appAccessKeyId=${appAccessKeyId};appSign=${appSign};sign=${sign}`;\n    }\n\n    // 发出请求\n    // 新的 url 需要携带 env 参数进行 CORS 校验\n    // 请求链接支持添加动态 query 参数，方便用户调试定位请求\n    const { parse, inQuery, search } = params;\n    let formatQuery: Record<string, any> = {\n      env: this.config.env\n    };\n    // 尝试解析响应数据为 JSON\n    parse && (formatQuery.parse = true);\n    inQuery && (formatQuery = {\n      ...inQuery,\n      ...formatQuery\n    });\n    const { BASE_URL, PROTOCOL } = getEndPoint();\n    // 生成请求 url\n    let newUrl = formatUrl(PROTOCOL, BASE_URL, formatQuery);\n\n    if (search) {\n      newUrl += search;\n    }\n\n    const res: ResponseObject = await this.post({\n      url: newUrl,\n      data: payload,\n      ...opts\n    });\n\n    // 保存 trace header\n    const resTraceHeader = res.header && res.header['x-tcb-trace'];\n    if (resTraceHeader) {\n      this._localCache.setStore(tcbTraceKey, resTraceHeader);\n    }\n\n    if ((Number(res.status) !== 200 && Number(res.statusCode) !== 200) || !res.data) {\n      throw new Error('network request error');\n    }\n\n    return res;\n  }\n\n  public async send(action: string, data: KV<any> = {}): Promise<any> {\n    let response = await this.request(action, data, { onUploadProgress: data.onUploadProgress });\n    if (response.data.code === 'ACCESS_TOKEN_EXPIRED' && ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1) {\n      // access_token过期，重新获取\n      await this.refreshAccessToken();\n      response = await this.request(action, data, { onUploadProgress: data.onUploadProgress });\n    }\n\n    if (response.data.code && this._throwWhenRequestFail) {\n      throw new Error(JSON.stringify({\n        code: ERRORS.OPERATION_FAIL,\n        msg: `[${response.data.code}] ${response.data.message}`\n      }));\n    }\n\n    return response.data;\n  }\n\n  // 调用接口刷新access token，并且返回\n  private async _refreshAccessToken(retryNum = 1): Promise<IGetAccessTokenResult> {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey, loginTypeKey, anonymousUuidKey } = this._cache.keys;\n    await this._cache.removeStoreAsync(accessTokenKey);\n    await this._cache.removeStoreAsync(accessTokenExpireKey);\n\n    let refreshToken = await this._cache.getStoreAsync(refreshTokenKey);\n    if (!refreshToken) {\n      throw new Error(JSON.stringify({\n        code: ERRORS.INVALID_OPERATION,\n        msg: 'not login'\n      }));\n    }\n    const params: KV<string> = {\n      refresh_token: refreshToken\n    };\n    const response = await this.request('auth.fetchAccessTokenWithRefreshToken', params);\n    if (response.data.code) {\n      const { code } = response.data;\n      if (code === 'SIGN_PARAM_INVALID' || code === 'REFRESH_TOKEN_EXPIRED' || code === 'INVALID_REFRESH_TOKEN') {\n        // 这里处理以下逻辑：\n        // 匿名登录时，如果刷新access token报错refresh token过期，此时应该：\n        // 1. 再用 uuid 拿一次新的refresh token\n        // 2. 拿新的refresh token换access token\n        const isAnonymous = await this._cache.getStoreAsync(loginTypeKey) === LOGINTYPE.ANONYMOUS;\n        if (isAnonymous && code === 'INVALID_REFRESH_TOKEN') {\n          // 获取新的 refresh token\n          const anonymous_uuid = await this._cache.getStoreAsync(anonymousUuidKey);\n          // 此处cache为基类property\n          const refresh_token = await this._cache.getStoreAsync(refreshTokenKey);\n          const res = await this.send('auth.signInAnonymously', {\n            anonymous_uuid,\n            refresh_token\n          });\n          this._setRefreshToken(res.refresh_token);\n          if (retryNum >= 1) {\n            return this._refreshAccessToken(--retryNum);\n          } else {\n            throw new Error(\n              JSON.stringify({\n                code: ERRORS.OPERATION_FAIL,\n                message: '重试获取 refresh token 失败'\n              })\n            )\n          }\n        }\n        cloudbase.fire(EVENTS.LOGIN_STATE_EXPIRED);\n        await this._cache.removeStoreAsync(refreshTokenKey);\n      }\n      throw new Error(JSON.stringify({\n        code: ERRORS.NETWORK_ERROR,\n        msg: `refresh access_token failed：${response.data.code}`\n      }));\n    }\n    if (response.data.access_token) {\n      cloudbase.fire(EVENTS.ACCESS_TOKEN_REFRESHD);\n      await this._cache.setStoreAsync(accessTokenKey, response.data.access_token);\n      // 本地时间可能没有同步\n      await this._cache.setStoreAsync(accessTokenExpireKey, response.data.access_token_expire + Date.now());\n      return {\n        accessToken: response.data.access_token,\n        accessTokenExpire: response.data.access_token_expire\n      };\n    }\n    // 匿名登录refresh_token过期情况下返回refresh_token\n    // 此场景下使用新的refresh_token获取access_token\n    if (response.data.refresh_token) {\n      await this._cache.removeStoreAsync(refreshTokenKey);\n      await this._cache.setStoreAsync(refreshTokenKey, response.data.refresh_token);\n      await this._refreshAccessToken();\n    }\n  }\n\n  private async _fetchAccessTokenFromOauthServer(refreshToken: string, clientId: string) {\n    const resp = await this.fetch('/auth/v1/token', {\n      method: 'POST',\n      headers: {\n        'Accept': 'application/json',\n        'Content-Type': 'application/json'\n      },\n      body: JSON.stringify({\n        grant_type: 'refresh_token',\n        client_id: clientId,\n        refresh_token: refreshToken\n      })\n    })\n    // Resp:\n    // {\n    //   \"token_type\": \"Bearer\",\n    //   \"access_token\": \"\",\n    //   \"refresh_token\":\"\",\n    //   \"expires_in\": 259200,\n    //   \"sub\": \"\"\n    // }\n    // 以下代码重复\n    const seqIdFromHeader = resp.headers.get('SeqId') || resp.headers.get('RequestId')\n    if (resp.status >= 400 && resp.status < 500) {\n      const body: any = await resp.json()\n      const seqId = body.request_id || seqIdFromHeader\n      throw new Error(`[${getSdkName()}/${getSdkVersion()}][OAuth2AuthProvider][status:${resp.status}][${body.error}(${body.error_code})] ${body.error_description} (${seqId})`)\n    }\n    else if (resp.status >= 500) {\n      const body: any = await resp.json()\n      const seqId = body.request_id || seqIdFromHeader\n      throw new Error(`[${getSdkName()}/${getSdkVersion()}][OAuth2AuthProvider][status:${resp.status}][${body.error}(${body.error_code})] ${body.error_description} (${seqId})`)\n    }\n    return resp.json()\n  }\n\n  // 调用接口刷新access token，并且返回\n  private async _refreshAccessTokenFromOauthServer(clientId: string): Promise<IGetAccessTokenResult> {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys;\n    const refreshToken = await this._cache.getStoreAsync(refreshTokenKey);\n    if (!refreshToken) {\n      throw new Error(JSON.stringify({\n        code: ERRORS.INVALID_OPERATION,\n        msg: 'not login'\n      }));\n    }\n\n    const token = await this._fetchAccessTokenFromOauthServer(refreshToken, clientId);\n    const { refresh_token: newRefreshToken, access_token: accessToken, expires_in: accessTokenExpire } = token\n\n    // 错误处理\n    if (!accessToken || !accessTokenExpire) {\n      throw new Error(JSON.stringify({\n        code: ERRORS.NETWORK_ERROR,\n        msg: 'refresh access_token failed'\n      }));\n    }\n    if (accessToken && accessTokenExpire) {\n      if (newRefreshToken === refreshToken) {\n        await this._cache.setStoreAsync(refreshTokenKey, newRefreshToken);\n      }\n      await this._cache.setStoreAsync(accessTokenKey, accessToken);\n      await this._cache.setStoreAsync(accessTokenExpireKey, accessTokenExpire * 1000 + Date.now());\n      cloudbase.fire(EVENTS.ACCESS_TOKEN_REFRESHD);\n      return {\n        accessToken: accessToken,\n        accessTokenExpire: accessTokenExpire\n      };\n    }\n  }\n\n  private async _setRefreshToken(refreshToken: string) {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys;\n    // refresh token设置前，先清掉 access token\n    // 设置是直接拉取新 access token 覆盖，而不是 remove\n    await this._cache.removeStoreAsync(accessTokenKey);\n    await this._cache.removeStoreAsync(accessTokenExpireKey);\n    await this._cache.setStoreAsync(refreshTokenKey, refreshToken);\n  }\n\n  private async getDeviceId(): Promise<string> {\n    const { deviceIdKey } = this._cache.keys\n    const deviceId = await this._cache.getStoreAsync(deviceIdKey)\n\n    if (!deviceId) {\n      // const fp = await fpPromise\n      // const result = await fp.get()\n      // const deviceId = result.visitorId\n      const newDeviceId = uuidv4()\n      this._cache.setStoreAsync(deviceIdKey, newDeviceId)\n      return newDeviceId\n    }\n    else {\n      return deviceId\n    }\n  }\n\n  private async checkFromAuthV2() {\n    // const authInstance = this._fromApp.authInstance\n    const oauthInstance = this._fromApp.oauthInstance || (this._fromApp as any).oauth()\n    // const authLogin = authInstance && await authInstance.getLoginState()\n    // console.log('authLogin', authLogin)\n    // if (authLogin) {\n    //   return 'auth'\n    // }\n    const oauthLogin = oauthInstance && await oauthInstance.hasLoginState()\n    if (oauthLogin) {\n      return 'oauth'\n    }\n    return ''\n  }\n}\n\nconst requestMap: KV<CloudbaseRequest> = {};\n\nexport function initRequest(config: ICloudbaseRequestConfig) {\n  requestMap[config.env] = new CloudbaseRequest({\n    ...config,\n    throw: true\n  });\n}\n\nexport function getRequestByEnvId(env: string): CloudbaseRequest {\n  return requestMap[env];\n}"]}
|
|
490
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request.js","sourceRoot":"","sources":["../../../src/libs/request.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-plusplus */\n/* eslint-disable no-prototype-builtins */\n/* eslint-disable no-restricted-syntax */\n/* eslint-disable @typescript-eslint/no-misused-promises */\nimport {\n  DATA_VERSION,\n  LOGINTYPE,\n  getSdkVersion,\n  getEndPoint,\n} from '../constants/common';\nimport {\n  IRequestOptions,\n  SDKRequestInterface,\n  ResponseObject,\n  IUploadRequestOptions,\n  IRequestConfig,\n} from '@cloudbase/adapter-interface';\nimport { utils, adapters, constants } from '@cloudbase/utilities';\nimport { KV } from '@cloudbase/types';\nimport { IGetAccessTokenResult, ICloudbaseRequestConfig, IAppendedRequestInfo, IRequestBeforeHook } from '@cloudbase/types/request';\nimport { ICloudbaseCache } from '@cloudbase/types/cache';\nimport { cloudbase } from '..';\nimport { getCacheByEnvId, getLocalCache } from './cache';\nimport { EVENTS } from '../constants/events';\nimport { Platform } from './adapter';\n\nconst { ERRORS } = constants;\nconst { genSeqId, isFormData, formatUrl, createSign } = utils;\nconst { RUNTIME } = adapters;\n\n// 下面几种 action 不需要 access token\nconst ACTIONS_WITHOUT_ACCESSTOKEN = [\n  'auth.getJwt',\n  'auth.logout',\n  'auth.signInWithTicket',\n  'auth.signInAnonymously',\n  'auth.signIn',\n  'auth.fetchAccessTokenWithRefreshToken',\n  'auth.signUpWithEmailAndPassword',\n  'auth.activateEndUserMail',\n  'auth.sendPasswordResetEmail',\n  'auth.resetPasswordWithToken',\n  'auth.isUsernameRegistered',\n];\n\nfunction bindHooks(instance: SDKRequestInterface, name: string, hooks: IRequestBeforeHook[]) {\n  const originMethod = instance[name];\n  instance[name] = function (options: IRequestOptions) {\n    const data = {};\n    const headers = {};\n    hooks.forEach((hook) => {\n      const { data: appendedData, headers: appendedHeaders } = hook.call(instance, options);\n      Object.assign(data, appendedData);\n      Object.assign(headers, appendedHeaders);\n    });\n    const originData = options.data;\n    originData && (() => {\n      if (isFormData(originData)) {\n        for (const key in data) {\n          (originData as FormData).append(key, data[key]);\n        }\n        return;\n      }\n      options.data = {\n        ...originData,\n        ...data,\n      };\n    })();\n    options.headers = {\n      ...(options.headers || {}),\n      ...headers,\n    };\n    return (originMethod as Function).call(instance, options);\n  };\n}\nfunction beforeEach(): IAppendedRequestInfo {\n  const seqId = genSeqId();\n  return {\n    data: {\n      seqId,\n    },\n    headers: {\n      'X-SDK-Version': `@cloudbase/js-sdk/${getSdkVersion()}`,\n      'x-seqid': seqId,\n    },\n  };\n}\nexport interface ICloudbaseRequest {\n  post: (options: IRequestOptions) => Promise<ResponseObject>;\n  upload: (options: IUploadRequestOptions) => Promise<ResponseObject>;\n  download: (options: IRequestOptions) => Promise<ResponseObject>;\n  refreshAccessToken: () => Promise<IGetAccessTokenResult>;\n  getAccessToken: () => Promise<IGetAccessTokenResult>;\n  request: (action: string, params: KV<any>, options?: KV<any>) => Promise<ResponseObject>;\n  send: (action: string, data: KV<any>) => Promise<any>;\n}\n\n/**\n * @class CloudbaseRequest\n */\nexport class CloudbaseRequest implements ICloudbaseRequest {\n  config: ICloudbaseRequestConfig;\n  _shouldRefreshAccessTokenHook: Function;\n  _refreshAccessTokenPromise: Promise<IGetAccessTokenResult> | null;\n  _reqClass: SDKRequestInterface;\n  // 请求失败是否抛出Error\n  private _throwWhenRequestFail = false;\n  private _cache: ICloudbaseCache;\n  // 持久化本地存储\n  private _localCache: ICloudbaseCache;\n  /**\n   * 初始化\n   * @param config\n   */\n  constructor(config: ICloudbaseRequestConfig & { throw?: boolean }) {\n    this.config = config;\n    // eslint-disable-next-line\n    this._reqClass = new Platform.adapter.reqClass(<IRequestConfig>{\n      timeout: this.config.timeout,\n      timeoutMsg: `[@cloudbase/js-sdk] 请求在${this.config.timeout / 1000}s内未完成，已中断`,\n      restrictedMethods: ['post'],\n    });\n    this._throwWhenRequestFail = config.throw || false;\n    this._cache = getCacheByEnvId(this.config.env);\n    this._localCache = getLocalCache(this.config.env);\n    bindHooks(this._reqClass, 'post', [beforeEach]);\n    bindHooks(this._reqClass, 'upload', [beforeEach]);\n    bindHooks(this._reqClass, 'download', [beforeEach]);\n  }\n  public async post(options: IRequestOptions): Promise<ResponseObject> {\n    const res = await this._reqClass.post(options);\n    return res;\n  }\n  public async upload(options: IUploadRequestOptions): Promise<ResponseObject> {\n    const res = await this._reqClass.upload(options);\n    return res;\n  }\n  public async download(options: IRequestOptions): Promise<ResponseObject> {\n    const res = await this._reqClass.download(options);\n    return res;\n  }\n\n  public async refreshAccessToken(): Promise<IGetAccessTokenResult> {\n    // 可能会同时调用多次刷新access token，这里把它们合并成一个\n    if (!this._refreshAccessTokenPromise) {\n      // 没有正在刷新，那么正常执行刷新逻辑\n      this._refreshAccessTokenPromise = this._refreshAccessToken();\n    }\n\n    let result;\n    let err;\n    try {\n      result = await this._refreshAccessTokenPromise;\n    } catch (e) {\n      err = e;\n    }\n    this._refreshAccessTokenPromise = null;\n    this._shouldRefreshAccessTokenHook = null;\n    if (err) {\n      throw err;\n    }\n    return result;\n  }\n\n  // 获取access token\n  public async getAccessToken(): Promise<IGetAccessTokenResult> {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys;\n    const refreshToken = await this._cache.getStoreAsync(refreshTokenKey);\n    if (!refreshToken) {\n      // 不该出现的状态：有 access token 却没有 refresh token\n      throw new Error(JSON.stringify({\n        code: ERRORS.OPERATION_FAIL,\n        msg: 'refresh token is not exist, your local data might be messed up, please retry after clear localStorage or sessionStorage',\n      }));\n    }\n    // 如果没有access token或者过期，那么刷新\n    const accessToken = await this._cache.getStoreAsync(accessTokenKey);\n    const accessTokenExpire = Number(await this._cache.getStoreAsync(accessTokenExpireKey));\n\n    // 调用钩子函数\n    let shouldRefreshAccessToken = true;\n    if (this._shouldRefreshAccessTokenHook && !(await this._shouldRefreshAccessTokenHook(accessToken, accessTokenExpire))) {\n      shouldRefreshAccessToken = false;\n    }\n\n    if ((!accessToken || !accessTokenExpire || accessTokenExpire < Date.now()) && shouldRefreshAccessToken) {\n      // 返回新的access tolen\n      return await this.refreshAccessToken();\n    }\n    // 返回本地的access token\n    return {\n      accessToken,\n      accessTokenExpire,\n    };\n  }\n\n  /* eslint-disable complexity */\n  public async request(action: string, params: KV<any>, options?: KV<any>): Promise<ResponseObject> {\n    const tcbTraceKey = `x-tcb-trace_${this.config.env}`;\n    let contentType = 'application/x-www-form-urlencoded';\n    // const webDeviceId = await getTcbFingerprintId();\n    const tmpObj: KV<any> = {\n      action,\n      // webDeviceId,\n      dataVersion: DATA_VERSION,\n      env: this.config.env,\n      ...params,\n    };\n\n\n    if (ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1) {\n      const { refreshTokenKey } = this._cache.keys;\n\n      // 若有 refreshToken 则任务有登录态 刷 accessToken\n      const refreshToken = await this._cache.getStoreAsync(refreshTokenKey);\n      if (refreshToken) {\n        tmpObj.access_token = (await this.getAccessToken()).accessToken;\n      }\n    }\n\n    // 拼body和content-type\n    let payload;\n    if (action === 'storage.uploadFile') {\n      payload = new FormData();\n      for (const key in payload) {\n        if (payload.hasOwnProperty(key) && payload[key] !== undefined) {\n          payload.append(key, tmpObj[key]);\n        }\n      }\n      contentType = 'multipart/form-data';\n    } else {\n      contentType = 'application/json;charset=UTF-8';\n      payload = {};\n      for (const key in tmpObj) {\n        if (tmpObj[key] !== undefined) {\n          payload[key] = tmpObj[key];\n        }\n      }\n    }\n    const opts: any = {\n      headers: {\n        'content-type': contentType,\n      },\n    };\n    if (options?.onUploadProgress) {\n      opts.onUploadProgress = options.onUploadProgress;\n    }\n\n    if (this.config.region) {\n      opts.headers['X-TCB-Region'] = this.config.region;\n    }\n\n    const traceHeader = this._localCache.getStore(tcbTraceKey);\n    if (traceHeader) {\n      opts.headers['X-TCB-Trace'] = traceHeader;\n    }\n    // 非web平台使用凭证检验有效性\n    if (Platform.runtime !== RUNTIME.WEB) {\n      const { appSign, appSecret } = this.config;\n      const timestamp = Date.now();\n      const { appAccessKey, appAccessKeyId } = appSecret;\n      const sign = createSign({\n        data: {}, // 校验签名流程实际未用到，可设空\n        timestamp,\n        appAccessKeyId,\n        appSign,\n      }, appAccessKey);\n\n      opts.headers['X-TCB-App-Source'] = `timestamp=${timestamp};appAccessKeyId=${appAccessKeyId};appSign=${appSign};sign=${sign}`;\n    }\n\n    // 发出请求\n    // 新的 url 需要携带 env 参数进行 CORS 校验\n    // 请求链接支持添加动态 query 参数，方便用户调试定位请求\n    const { parse, inQuery, search } = params;\n    let formatQuery: Record<string, any> = {\n      env: this.config.env,\n    };\n    // 尝试解析响应数据为 JSON\n    parse && (formatQuery.parse = true);\n    inQuery && (formatQuery = {\n      ...inQuery,\n      ...formatQuery,\n    });\n    const { BASE_URL, PROTOCOL } = getEndPoint();\n    // 生成请求 url\n    let newUrl = formatUrl(PROTOCOL, BASE_URL, formatQuery);\n\n    if (search) {\n      newUrl += search;\n    }\n\n    const res: ResponseObject = await this.post({\n      url: newUrl,\n      data: payload,\n      ...opts,\n    });\n\n    // 保存 trace header\n    const resTraceHeader = res.header && res.header['x-tcb-trace'];\n    if (resTraceHeader) {\n      this._localCache.setStore(tcbTraceKey, resTraceHeader);\n    }\n\n    if ((Number(res.status) !== 200 && Number(res.statusCode) !== 200) || !res.data) {\n      throw new Error('network request error');\n    }\n\n    return res;\n  }\n\n  public async send(action: string, data: KV<any> = {}): Promise<any> {\n    let response = await this.request(action, data, { onUploadProgress: data.onUploadProgress });\n    if (response.data.code === 'ACCESS_TOKEN_EXPIRED' && ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1) {\n      // access_token过期，重新获取\n      await this.refreshAccessToken();\n      response = await this.request(action, data, { onUploadProgress: data.onUploadProgress });\n    }\n\n    if (response.data.code && this._throwWhenRequestFail) {\n      throw new Error(JSON.stringify({\n        code: ERRORS.OPERATION_FAIL,\n        msg: `[${response.data.code}] ${response.data.message}`,\n      }));\n    }\n\n    return response.data;\n  }\n\n  // 调用接口刷新access token，并且返回\n  private async _refreshAccessToken(retryNum = 1): Promise<IGetAccessTokenResult> {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey, loginTypeKey, anonymousUuidKey } = this._cache.keys;\n    await this._cache.removeStoreAsync(accessTokenKey);\n    await this._cache.removeStoreAsync(accessTokenExpireKey);\n\n    const refreshToken = await this._cache.getStoreAsync(refreshTokenKey);\n    if (!refreshToken) {\n      throw new Error(JSON.stringify({\n        code: ERRORS.INVALID_OPERATION,\n        msg: 'not login',\n      }));\n    }\n    const params: KV<string> = {\n      refresh_token: refreshToken,\n    };\n    const response = await this.request('auth.fetchAccessTokenWithRefreshToken', params);\n    if (response.data.code) {\n      const { code } = response.data;\n      if (code === 'SIGN_PARAM_INVALID' || code === 'REFRESH_TOKEN_EXPIRED' || code === 'INVALID_REFRESH_TOKEN') {\n        // 这里处理以下逻辑：\n        // 匿名登录时，如果刷新access token报错refresh token过期，此时应该：\n        // 1. 再用 uuid 拿一次新的refresh token\n        // 2. 拿新的refresh token换access token\n        const isAnonymous = await this._cache.getStoreAsync(loginTypeKey) === LOGINTYPE.ANONYMOUS;\n        if (isAnonymous && code === 'INVALID_REFRESH_TOKEN') {\n          // 获取新的 refresh token\n          const anonymous_uuid = await this._cache.getStoreAsync(anonymousUuidKey);\n          // 此处cache为基类property\n          const refresh_token = await this._cache.getStoreAsync(refreshTokenKey);\n          const res = await this.send('auth.signInAnonymously', {\n            anonymous_uuid,\n            refresh_token,\n          });\n          this._setRefreshToken(res.refresh_token);\n          if (retryNum >= 1) {\n            return this._refreshAccessToken(--retryNum);\n          }\n          throw new Error(JSON.stringify({\n            code: ERRORS.OPERATION_FAIL,\n            message: '重试获取 refresh token 失败',\n          }));\n        }\n        cloudbase.fire(EVENTS.LOGIN_STATE_EXPIRED);\n        await this._cache.removeStoreAsync(refreshTokenKey);\n      }\n      throw new Error(JSON.stringify({\n        code: ERRORS.NETWORK_ERROR,\n        msg: `refresh access_token failed：${response.data.code}`,\n      }));\n    }\n    if (response.data.access_token) {\n      cloudbase.fire(EVENTS.ACCESS_TOKEN_REFRESHD);\n      await this._cache.setStoreAsync(accessTokenKey, response.data.access_token);\n      // 本地时间可能没有同步\n      await this._cache.setStoreAsync(accessTokenExpireKey, response.data.access_token_expire + Date.now());\n      return {\n        accessToken: response.data.access_token,\n        accessTokenExpire: response.data.access_token_expire,\n      };\n    }\n    // 匿名登录refresh_token过期情况下返回refresh_token\n    // 此场景下使用新的refresh_token获取access_token\n    if (response.data.refresh_token) {\n      await this._cache.removeStoreAsync(refreshTokenKey);\n      await this._cache.setStoreAsync(refreshTokenKey, response.data.refresh_token);\n      await this._refreshAccessToken();\n    }\n  }\n  private async _setRefreshToken(refreshToken: string) {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys;\n    // refresh token设置前，先清掉 access token\n    await this._cache.removeStoreAsync(accessTokenKey);\n    await this._cache.removeStoreAsync(accessTokenExpireKey);\n    await this._cache.setStoreAsync(refreshTokenKey, refreshToken);\n  }\n}\n\nconst requestMap: KV<CloudbaseRequest> = {};\n\nexport function initRequest(config: ICloudbaseRequestConfig) {\n  requestMap[config.env] = new CloudbaseRequest({\n    ...config,\n    throw: true,\n  });\n}\n\nexport function getRequestByEnvId(env: string): CloudbaseRequest {\n  return requestMap[env];\n}\n"]}
|