@cloudbase/oauth 0.1.1-alpha.12 → 0.1.1-alpha.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (62) hide show
  1. package/dist/auth/consts.d.ts +1 -0
  2. package/dist/auth/consts.js +1 -0
  3. package/dist/auth/index.d.ts +11 -0
  4. package/dist/auth/index.js +11 -0
  5. package/dist/package.json +1 -1
  6. package/package.json +1 -1
  7. package/packages/app/dist/cjs/constants/common.d.ts +24 -0
  8. package/packages/app/dist/cjs/constants/common.js +68 -0
  9. package/packages/app/dist/cjs/index.d.ts +4 -0
  10. package/packages/app/dist/cjs/index.js +248 -0
  11. package/packages/app/dist/cjs/libs/adapter.d.ts +2 -0
  12. package/packages/app/dist/cjs/libs/adapter.js +5 -0
  13. package/packages/app/dist/cjs/libs/cache.d.ts +6 -0
  14. package/packages/app/dist/cjs/libs/cache.js +38 -0
  15. package/packages/app/dist/cjs/libs/component.d.ts +3 -0
  16. package/packages/app/dist/cjs/libs/component.js +126 -0
  17. package/packages/app/dist/cjs/libs/request.d.ts +28 -0
  18. package/packages/app/dist/cjs/libs/request.js +298 -0
  19. package/packages/app/dist/esm/constants/common.d.ts +24 -0
  20. package/packages/app/dist/esm/constants/common.js +57 -0
  21. package/packages/app/dist/esm/index.d.ts +4 -0
  22. package/packages/app/dist/esm/index.js +241 -0
  23. package/packages/app/dist/esm/libs/adapter.d.ts +2 -0
  24. package/packages/app/dist/esm/libs/adapter.js +2 -0
  25. package/packages/app/dist/esm/libs/cache.d.ts +6 -0
  26. package/packages/app/dist/esm/libs/cache.js +32 -0
  27. package/packages/app/dist/esm/libs/component.d.ts +3 -0
  28. package/packages/app/dist/esm/libs/component.js +121 -0
  29. package/packages/app/dist/esm/libs/request.d.ts +28 -0
  30. package/packages/app/dist/esm/libs/request.js +293 -0
  31. package/packages/auth/dist/cjs/index.d.ts +117 -0
  32. package/packages/auth/dist/cjs/index.js +1082 -0
  33. package/packages/auth/dist/esm/index.d.ts +117 -0
  34. package/packages/auth/dist/esm/index.js +1078 -0
  35. package/packages/cloudbase/app/dist/index.esm.js +10 -0
  36. package/packages/cloudbase/auth/dist/index.esm.js +4 -0
  37. package/packages/cloudbase/dist/index.cjs.js +31 -0
  38. package/packages/cloudbase/dist/index.esm.js +26 -0
  39. package/packages/cloudbase/functions/dist/index.esm.js +4 -0
  40. package/packages/cloudbase/storage/dist/index.esm.js +4 -0
  41. package/packages/functions/dist/cjs/index.d.ts +2 -0
  42. package/packages/functions/dist/cjs/index.js +165 -0
  43. package/packages/functions/dist/esm/index.d.ts +2 -0
  44. package/packages/functions/dist/esm/index.js +161 -0
  45. package/packages/oauth/dist/cjs/auth/apis.d.ts +11 -1
  46. package/packages/oauth/dist/cjs/auth/apis.js +52 -1
  47. package/packages/oauth/dist/cjs/auth/consts.d.ts +5 -1
  48. package/packages/oauth/dist/cjs/auth/consts.js +5 -1
  49. package/packages/oauth/dist/cjs/auth/models.d.ts +17 -0
  50. package/packages/oauth/dist/cjs/auth/models.js +1 -1
  51. package/packages/oauth/dist/esm/auth/apis.d.ts +11 -1
  52. package/packages/oauth/dist/esm/auth/apis.js +52 -1
  53. package/packages/oauth/dist/esm/auth/consts.d.ts +5 -1
  54. package/packages/oauth/dist/esm/auth/consts.js +5 -1
  55. package/packages/oauth/dist/esm/auth/models.d.ts +17 -0
  56. package/packages/oauth/dist/esm/auth/models.js +1 -1
  57. package/packages/storage/dist/cjs/index.d.ts +2 -0
  58. package/packages/storage/dist/cjs/index.js +426 -0
  59. package/packages/storage/dist/esm/index.d.ts +2 -0
  60. package/packages/storage/dist/esm/index.js +422 -0
  61. package/src/auth/consts.ts +2 -1
  62. package/src/auth/index.ts +18 -0
@@ -0,0 +1,293 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
23
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ 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;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
48
+ import { DATA_VERSION, getSdkVersion, getEndPoint, getBaseEndPoint, } from '../constants/common';
49
+ import { utils, constants } from '@cloudbase/utilities';
50
+ import { getLocalCache } from './cache';
51
+ import { Platform } from './adapter';
52
+ var ERRORS = constants.ERRORS;
53
+ var genSeqId = utils.genSeqId, isFormData = utils.isFormData, formatUrl = utils.formatUrl;
54
+ var ACTIONS_WITHOUT_ACCESSTOKEN = [
55
+ 'auth.getJwt',
56
+ 'auth.logout',
57
+ 'auth.signInWithTicket',
58
+ 'auth.signInAnonymously',
59
+ 'auth.signIn',
60
+ 'auth.signInWithWechat',
61
+ 'auth.fetchAccessTokenWithRefreshToken',
62
+ 'auth.signUpWithEmailAndPassword',
63
+ 'auth.activateEndUserMail',
64
+ 'auth.sendPasswordResetEmail',
65
+ 'auth.resetPasswordWithToken',
66
+ 'auth.isUsernameRegistered',
67
+ ];
68
+ function bindHooks(instance, name, hooks) {
69
+ var originMethod = instance[name];
70
+ instance[name] = function (options) {
71
+ var data = {};
72
+ var headers = {};
73
+ hooks.forEach(function (hook) {
74
+ var _a = hook.call(instance, options), appendedData = _a.data, appendedHeaders = _a.headers;
75
+ Object.assign(data, appendedData);
76
+ Object.assign(headers, appendedHeaders);
77
+ });
78
+ var originData = options.data;
79
+ originData && (function () {
80
+ if (isFormData(originData)) {
81
+ Object.keys(data).forEach(function (key) {
82
+ originData.append(key, data[key]);
83
+ });
84
+ return;
85
+ }
86
+ options.data = __assign(__assign({}, originData), data);
87
+ })();
88
+ options.headers = __assign(__assign({}, (options.headers || {})), headers);
89
+ return originMethod.call(instance, options);
90
+ };
91
+ }
92
+ function beforeEach() {
93
+ var seqId = genSeqId();
94
+ return {
95
+ data: {
96
+ seqId: seqId,
97
+ },
98
+ headers: {
99
+ 'X-SDK-Version': "@cloudbase/js-sdk/".concat(getSdkVersion()),
100
+ 'x-seqid': seqId,
101
+ },
102
+ };
103
+ }
104
+ var CloudbaseRequest = (function () {
105
+ function CloudbaseRequest(config) {
106
+ this.throwWhenRequestFail = false;
107
+ this.config = config;
108
+ var reqConfig = {
109
+ timeout: this.config.timeout,
110
+ timeoutMsg: "[@cloudbase/js-sdk] \u8BF7\u6C42\u5728".concat(this.config.timeout / 1000, "s\u5185\u672A\u5B8C\u6210\uFF0C\u5DF2\u4E2D\u65AD"),
111
+ restrictedMethods: ['post', 'put'],
112
+ };
113
+ this.reqClass = new Platform.adapter.reqClass(reqConfig);
114
+ this.throwWhenRequestFail = config.throw || false;
115
+ this.localCache = getLocalCache(this.config.env);
116
+ bindHooks(this.reqClass, 'post', [beforeEach]);
117
+ bindHooks(this.reqClass, 'upload', [beforeEach]);
118
+ bindHooks(this.reqClass, 'download', [beforeEach]);
119
+ }
120
+ CloudbaseRequest.prototype.post = function (options) {
121
+ return __awaiter(this, void 0, void 0, function () {
122
+ var res;
123
+ return __generator(this, function (_a) {
124
+ switch (_a.label) {
125
+ case 0: return [4, this.reqClass.post(options)];
126
+ case 1:
127
+ res = _a.sent();
128
+ return [2, res];
129
+ }
130
+ });
131
+ });
132
+ };
133
+ CloudbaseRequest.prototype.upload = function (options) {
134
+ return __awaiter(this, void 0, void 0, function () {
135
+ var res;
136
+ return __generator(this, function (_a) {
137
+ switch (_a.label) {
138
+ case 0: return [4, this.reqClass.upload(options)];
139
+ case 1:
140
+ res = _a.sent();
141
+ return [2, res];
142
+ }
143
+ });
144
+ });
145
+ };
146
+ CloudbaseRequest.prototype.download = function (options) {
147
+ return __awaiter(this, void 0, void 0, function () {
148
+ var res;
149
+ return __generator(this, function (_a) {
150
+ switch (_a.label) {
151
+ case 0: return [4, this.reqClass.download(options)];
152
+ case 1:
153
+ res = _a.sent();
154
+ return [2, res];
155
+ }
156
+ });
157
+ });
158
+ };
159
+ CloudbaseRequest.prototype.getBaseEndPoint = function () {
160
+ return getBaseEndPoint();
161
+ };
162
+ CloudbaseRequest.prototype.getOauthAccessTokenV2 = function (oauthClient) {
163
+ return __awaiter(this, void 0, void 0, function () {
164
+ var validAccessToken, credentials;
165
+ return __generator(this, function (_a) {
166
+ switch (_a.label) {
167
+ case 0: return [4, oauthClient.getAccessToken()];
168
+ case 1:
169
+ validAccessToken = _a.sent();
170
+ return [4, oauthClient.getCredentials()];
171
+ case 2:
172
+ credentials = _a.sent();
173
+ return [2, {
174
+ accessToken: validAccessToken,
175
+ accessTokenExpire: new Date(credentials.expires_at).getTime(),
176
+ }];
177
+ }
178
+ });
179
+ });
180
+ };
181
+ CloudbaseRequest.prototype.request = function (action, params, options) {
182
+ var _a;
183
+ return __awaiter(this, void 0, void 0, function () {
184
+ var tcbTraceKey, contentType, tmpObj, app, oauthInstance, oauthClient, _b, payload, opts, traceHeader, parse, inQuery, search, formatQuery, _c, BASE_URL, PROTOCOL, newUrl, res, resTraceHeader;
185
+ return __generator(this, function (_d) {
186
+ switch (_d.label) {
187
+ case 0:
188
+ tcbTraceKey = "x-tcb-trace_".concat(this.config.env);
189
+ contentType = 'application/x-www-form-urlencoded';
190
+ tmpObj = __assign({ action: action, dataVersion: DATA_VERSION, env: this.config.env }, params);
191
+ if (!(ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1)) return [3, 2];
192
+ app = this.config._fromApp;
193
+ if (!app.oauthInstance) {
194
+ throw new Error('you can\'t request without auth');
195
+ }
196
+ oauthInstance = app.oauthInstance;
197
+ oauthClient = oauthInstance.oauth2client;
198
+ _b = tmpObj;
199
+ return [4, this.getOauthAccessTokenV2(oauthClient)];
200
+ case 1:
201
+ _b.access_token = (_d.sent()).accessToken;
202
+ _d.label = 2;
203
+ case 2:
204
+ if (action === 'storage.uploadFile') {
205
+ payload = new FormData();
206
+ Object.keys(payload).forEach(function (key) {
207
+ if (Object.prototype.hasOwnProperty.call(payload, key) && payload[key] !== undefined) {
208
+ payload.append(key, tmpObj[key]);
209
+ }
210
+ });
211
+ contentType = 'multipart/form-data';
212
+ }
213
+ else {
214
+ contentType = 'application/json;charset=UTF-8';
215
+ payload = {};
216
+ Object.keys(tmpObj).forEach(function (key) {
217
+ if (tmpObj[key] !== undefined) {
218
+ payload[key] = tmpObj[key];
219
+ }
220
+ });
221
+ }
222
+ opts = {
223
+ headers: {
224
+ 'content-type': contentType,
225
+ },
226
+ };
227
+ if (options === null || options === void 0 ? void 0 : options.onUploadProgress) {
228
+ opts.onUploadProgress = options.onUploadProgress;
229
+ }
230
+ if (this.config.region) {
231
+ opts.headers['X-TCB-Region'] = this.config.region;
232
+ }
233
+ traceHeader = this.localCache.getStore(tcbTraceKey);
234
+ if (traceHeader) {
235
+ opts.headers['X-TCB-Trace'] = traceHeader;
236
+ }
237
+ parse = params.parse, inQuery = params.inQuery, search = params.search;
238
+ formatQuery = {
239
+ env: this.config.env,
240
+ };
241
+ parse && (formatQuery.parse = true);
242
+ inQuery && (formatQuery = __assign(__assign({}, inQuery), formatQuery));
243
+ _c = getEndPoint(), BASE_URL = _c.BASE_URL, PROTOCOL = _c.PROTOCOL;
244
+ newUrl = formatUrl(PROTOCOL, BASE_URL, formatQuery);
245
+ if (search) {
246
+ newUrl += search;
247
+ }
248
+ return [4, this.post(__assign({ url: newUrl, data: payload }, opts))];
249
+ case 3:
250
+ res = _d.sent();
251
+ resTraceHeader = (_a = res.header) === null || _a === void 0 ? void 0 : _a['x-tcb-trace'];
252
+ if (resTraceHeader) {
253
+ this.localCache.setStore(tcbTraceKey, resTraceHeader);
254
+ }
255
+ if ((Number(res.status) !== 200 && Number(res.statusCode) !== 200) || !res.data) {
256
+ throw new Error('network request error');
257
+ }
258
+ return [2, res];
259
+ }
260
+ });
261
+ });
262
+ };
263
+ CloudbaseRequest.prototype.send = function (action, data) {
264
+ if (data === void 0) { data = {}; }
265
+ return __awaiter(this, void 0, void 0, function () {
266
+ var response;
267
+ return __generator(this, function (_a) {
268
+ switch (_a.label) {
269
+ case 0: return [4, this.request(action, data, { onUploadProgress: data.onUploadProgress })];
270
+ case 1:
271
+ response = _a.sent();
272
+ if (response.data.code && this.throwWhenRequestFail) {
273
+ throw new Error(JSON.stringify({
274
+ code: ERRORS.OPERATION_FAIL,
275
+ msg: "[".concat(response.data.code, "] ").concat(response.data.message),
276
+ }));
277
+ }
278
+ return [2, response.data];
279
+ }
280
+ });
281
+ });
282
+ };
283
+ return CloudbaseRequest;
284
+ }());
285
+ export { CloudbaseRequest };
286
+ var requestMap = {};
287
+ export function initRequest(config) {
288
+ requestMap[config.env] = new CloudbaseRequest(__assign(__assign({}, config), { throw: true }));
289
+ }
290
+ export function getRequestByEnvId(env) {
291
+ return requestMap[env];
292
+ }
293
+ //# 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  getSdkVersion,\n  getEndPoint,\n  getBaseEndPoint,\n} from '../constants/common'\nimport {\n  IRequestOptions,\n  SDKRequestInterface,\n  ResponseObject,\n  IUploadRequestOptions,\n  IRequestConfig,\n} from '@cloudbase/adapter-interface'\nimport { utils, 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 { getLocalCache } from './cache'\nimport { Platform } from './adapter'\nconst { ERRORS } = constants\nconst { genSeqId, isFormData, formatUrl } = utils\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.signInWithWechat',\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        Object.keys(data).forEach((key) => {\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  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  private reqClass: SDKRequestInterface\n  // 请求失败是否抛出Error\n  private throwWhenRequestFail = false\n  // 持久化本地存储\n  private localCache: ICloudbaseCache\n  /**\n   * 初始化\n   * @param config\n   */\n  constructor(config: ICloudbaseRequestConfig & { throw?: boolean }) {\n    this.config = config\n    const reqConfig: IRequestConfig = {\n      timeout: this.config.timeout,\n      timeoutMsg: `[@cloudbase/js-sdk] 请求在${this.config.timeout / 1000}s内未完成，已中断`,\n      restrictedMethods: ['post', 'put'],\n    }\n    this.reqClass = new Platform.adapter.reqClass(reqConfig)\n    this.throwWhenRequestFail = config.throw || false\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  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 getBaseEndPoint() {\n    return getBaseEndPoint()\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\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 tmpObj: KV<any> = {\n      action,\n      dataVersion: DATA_VERSION,\n      env: this.config.env,\n      ...params,\n    }\n\n    if (ACTIONS_WITHOUT_ACCESSTOKEN.indexOf(action) === -1) {\n      const app = this.config._fromApp\n\n      if (!app.oauthInstance) {\n        throw new Error('you can\\'t request without auth')\n      }\n\n      const { oauthInstance } = app\n      const oauthClient = oauthInstance.oauth2client\n      tmpObj.access_token = (await this.getOauthAccessTokenV2(oauthClient)).accessToken\n    }\n\n    // 拼body和content-type\n    let payload\n    if (action === 'storage.uploadFile') {\n      payload = new FormData()\n      Object.keys(payload).forEach((key) => {\n        if (Object.prototype.hasOwnProperty.call(payload, 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      Object.keys(tmpObj).forEach((key) => {\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\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?.['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    const response = await this.request(action, data, { onUploadProgress: data.onUploadProgress })\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\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"]}
@@ -0,0 +1,117 @@
1
+ import { ICloudbase } from '@cloudbase/types';
2
+ import { ICloudbaseCache } from '@cloudbase/types/cache';
3
+ import { ICloudbaseRequest } from '@cloudbase/types/request';
4
+ import { ICloudbaseAuthConfig, IUser, IUserInfo, ILoginState } from '@cloudbase/types/auth';
5
+ import { authModels, CloudbaseOAuth, Credentials } from '@cloudbase/oauth';
6
+ import { ProviderSubType } from '@cloudbase/oauth/dist/cjs/auth/models';
7
+ interface UserInfo {
8
+ uid?: string;
9
+ gender?: string;
10
+ picture?: string;
11
+ email?: string;
12
+ email_verified?: boolean;
13
+ phone_number?: string;
14
+ username?: string;
15
+ name?: string;
16
+ birthdate?: string;
17
+ zoneinfo?: string;
18
+ locale?: string;
19
+ sub?: string;
20
+ created_from?: string;
21
+ }
22
+ interface IUserOptions {
23
+ cache: ICloudbaseCache;
24
+ oauthInstance: CloudbaseOAuth;
25
+ }
26
+ interface ILoginStateOptions extends IUserOptions {
27
+ envId: string;
28
+ }
29
+ export declare class LoginState implements ILoginState {
30
+ user: IUser;
31
+ oauthLoginState: any;
32
+ private oauthInstance;
33
+ private cache;
34
+ constructor(options: ILoginStateOptions);
35
+ checkLocalState(): void;
36
+ checkLocalStateAsync(): Promise<void>;
37
+ }
38
+ declare class Auth {
39
+ private readonly config;
40
+ private readonly cache;
41
+ private oauthInstance;
42
+ constructor(config: ICloudbaseAuthConfig & {
43
+ cache: ICloudbaseCache;
44
+ request?: ICloudbaseRequest;
45
+ runtime?: string;
46
+ });
47
+ bindPhoneNumber(params: authModels.BindPhoneRequest): Promise<void>;
48
+ unbindProvider(params: authModels.UnbindProviderRequest): Promise<void>;
49
+ bindEmail(params: authModels.BindEmailRequest): Promise<void>;
50
+ verify(params: authModels.VerifyRequest): Promise<authModels.VerifyResponse>;
51
+ getVerification(params: authModels.GetVerificationRequest): Promise<authModels.GetVerificationResponse>;
52
+ get currentUser(): IUser;
53
+ getCurrentUser(): Promise<IUser>;
54
+ signInAnonymously(data?: {
55
+ provider_token?: string;
56
+ }): Promise<LoginState>;
57
+ signInWithWechat(params?: any): Promise<LoginState>;
58
+ setCustomSignFunc(getTickFn: authModels.GetCustomSignTicketFn): void;
59
+ signInWithCustomTicket(params?: {
60
+ version?: string;
61
+ }): Promise<LoginState>;
62
+ signIn(params: authModels.SignInRequest): Promise<LoginState>;
63
+ signUp(params: authModels.SignUpRequest): Promise<LoginState>;
64
+ setPassword(params: authModels.SetPasswordRequest): Promise<void>;
65
+ isUsernameRegistered(username: string): Promise<boolean>;
66
+ signOut(): Promise<void>;
67
+ hasLoginState(): LoginState | null;
68
+ getLoginState(): Promise<LoginState>;
69
+ getUserInfo(params?: {
70
+ version?: string;
71
+ }): Promise<IUserInfo>;
72
+ getWedaUserInfo(): Promise<any>;
73
+ getAuthHeader(): {};
74
+ bindWithProvider(params: authModels.BindWithProviderRequest): Promise<void>;
75
+ queryUser(queryObj: authModels.QueryUserProfileRequest): Promise<authModels.QueryUserProfileResponse>;
76
+ getAccessToken(): Promise<{
77
+ accessToken: string;
78
+ env: string;
79
+ }>;
80
+ grantProviderToken(params: authModels.GrantProviderTokenRequest): Promise<authModels.GrantProviderTokenResponse>;
81
+ patchProviderToken(params: authModels.PatchProviderTokenRequest): Promise<authModels.PatchProviderTokenResponse>;
82
+ signInWithProvider(params: authModels.SignInWithProviderRequest): Promise<LoginState>;
83
+ grantToken(params: authModels.GrantTokenRequest): Promise<LoginState>;
84
+ genProviderRedirectUri(params: authModels.GenProviderRedirectUriRequest): Promise<authModels.GenProviderRedirectUriResponse>;
85
+ resetPassword(params: authModels.ResetPasswordRequest): Promise<void>;
86
+ deviceAuthorize(params: authModels.DeviceAuthorizeRequest): Promise<authModels.DeviceAuthorizeResponse>;
87
+ sudo(params: authModels.SudoRequest): Promise<authModels.SudoResponse>;
88
+ deleteMe(params: authModels.WithSudoRequest): Promise<authModels.UserProfile>;
89
+ getProviders(): Promise<authModels.UserProfileProvider>;
90
+ loginScope(): Promise<string>;
91
+ loginGroups(): Promise<string[]>;
92
+ onLoginStateChanged(callback: Function): Promise<void>;
93
+ refreshTokenForce(params: {
94
+ version?: string;
95
+ }): Promise<Credentials>;
96
+ getCredentials(): Promise<Credentials>;
97
+ getProviderSubType(): Promise<ProviderSubType>;
98
+ createCaptchaData(params: {
99
+ state: string;
100
+ redirect_uri?: string;
101
+ }): Promise<{
102
+ captcha_token: string;
103
+ expires_in: number;
104
+ }>;
105
+ verifyCaptchaData(params: {
106
+ token: string;
107
+ key: string;
108
+ }): Promise<{
109
+ captcha_token: string;
110
+ expires_in: number;
111
+ }>;
112
+ getMiniProgramCode(params: authModels.GetMiniProgramCodeRequest): Promise<authModels.GetMiniProgramCodeResponse>;
113
+ checkMiniProgramCode(params: authModels.CheckMiniProgramCodeRequest): Promise<authModels.CheckMiniProgramCodeResponse>;
114
+ private createLoginState;
115
+ }
116
+ export { UserInfo, Auth };
117
+ export declare function registerAuth(app: Pick<ICloudbase, 'registerComponent'>): void;