@cloudbase/auth 1.7.3-alpha.0 → 2.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/dist/cjs/index.d.ts +50 -101
  2. package/dist/cjs/index.js +415 -778
  3. package/dist/esm/index.d.ts +50 -101
  4. package/dist/esm/index.js +416 -775
  5. package/package.json +52 -54
  6. package/src/index.ts +401 -766
  7. package/dist/cjs/common.d.ts +0 -8
  8. package/dist/cjs/common.js +0 -64
  9. package/dist/cjs/constants.d.ts +0 -12
  10. package/dist/cjs/constants.js +0 -17
  11. package/dist/cjs/providers/anonymousAuthProvider.d.ts +0 -15
  12. package/dist/cjs/providers/anonymousAuthProvider.js +0 -256
  13. package/dist/cjs/providers/base.d.ts +0 -21
  14. package/dist/cjs/providers/base.js +0 -152
  15. package/dist/cjs/providers/customAuthProvider.d.ts +0 -5
  16. package/dist/cjs/providers/customAuthProvider.js +0 -150
  17. package/dist/cjs/providers/emailAuthProvider.d.ts +0 -9
  18. package/dist/cjs/providers/emailAuthProvider.js +0 -250
  19. package/dist/cjs/providers/oauth2AuthProvider.d.ts +0 -61
  20. package/dist/cjs/providers/oauth2AuthProvider.js +0 -404
  21. package/dist/cjs/providers/phoneAuthProvider.d.ts +0 -17
  22. package/dist/cjs/providers/phoneAuthProvider.js +0 -219
  23. package/dist/cjs/providers/usernameAuthProvider.d.ts +0 -5
  24. package/dist/cjs/providers/usernameAuthProvider.js +0 -169
  25. package/dist/cjs/providers/weixinAuthProvider.d.ts +0 -28
  26. package/dist/cjs/providers/weixinAuthProvider.js +0 -294
  27. package/dist/esm/common.d.ts +0 -8
  28. package/dist/esm/common.js +0 -61
  29. package/dist/esm/constants.d.ts +0 -12
  30. package/dist/esm/constants.js +0 -14
  31. package/dist/esm/providers/anonymousAuthProvider.d.ts +0 -15
  32. package/dist/esm/providers/anonymousAuthProvider.js +0 -253
  33. package/dist/esm/providers/base.d.ts +0 -21
  34. package/dist/esm/providers/base.js +0 -149
  35. package/dist/esm/providers/customAuthProvider.d.ts +0 -5
  36. package/dist/esm/providers/customAuthProvider.js +0 -147
  37. package/dist/esm/providers/emailAuthProvider.d.ts +0 -9
  38. package/dist/esm/providers/emailAuthProvider.js +0 -247
  39. package/dist/esm/providers/oauth2AuthProvider.d.ts +0 -61
  40. package/dist/esm/providers/oauth2AuthProvider.js +0 -401
  41. package/dist/esm/providers/phoneAuthProvider.d.ts +0 -17
  42. package/dist/esm/providers/phoneAuthProvider.js +0 -216
  43. package/dist/esm/providers/usernameAuthProvider.d.ts +0 -5
  44. package/dist/esm/providers/usernameAuthProvider.js +0 -166
  45. package/dist/esm/providers/weixinAuthProvider.d.ts +0 -28
  46. package/dist/esm/providers/weixinAuthProvider.js +0 -291
  47. package/src/common.ts +0 -21
  48. package/src/constants.ts +0 -13
  49. package/src/providers/anonymousAuthProvider.ts +0 -126
  50. package/src/providers/base.ts +0 -78
  51. package/src/providers/customAuthProvider.ts +0 -69
  52. package/src/providers/emailAuthProvider.ts +0 -142
  53. package/src/providers/oauth2AuthProvider.ts +0 -585
  54. package/src/providers/phoneAuthProvider.ts +0 -132
  55. package/src/providers/usernameAuthProvider.ts +0 -77
  56. package/src/providers/weixinAuthProvider.ts +0 -193
@@ -1,404 +0,0 @@
1
- "use strict";
2
- var __extends = (this && this.__extends) || (function () {
3
- var extendStatics = function (d, b) {
4
- extendStatics = Object.setPrototypeOf ||
5
- ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
- function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
7
- return extendStatics(d, b);
8
- };
9
- return function (d, b) {
10
- extendStatics(d, b);
11
- function __() { this.constructor = d; }
12
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
13
- };
14
- })();
15
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
16
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
17
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
18
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
19
- return c > 3 && r && Object.defineProperty(target, key, r), r;
20
- };
21
- var __metadata = (this && this.__metadata) || function (k, v) {
22
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
23
- };
24
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
25
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
26
- return new (P || (P = Promise))(function (resolve, reject) {
27
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
28
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
29
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
30
- step((generator = generator.apply(thisArg, _arguments || [])).next());
31
- });
32
- };
33
- var __generator = (this && this.__generator) || function (thisArg, body) {
34
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
35
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
36
- function verb(n) { return function (v) { return step([n, v]); }; }
37
- function step(op) {
38
- if (f) throw new TypeError("Generator is already executing.");
39
- while (_) try {
40
- 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;
41
- if (y = 0, t) op = [op[0] & 2, t.value];
42
- switch (op[0]) {
43
- case 0: case 1: t = op; break;
44
- case 4: _.label++; return { value: op[1], done: false };
45
- case 5: _.label++; y = op[1]; op = [0]; continue;
46
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
47
- default:
48
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
49
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
50
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
51
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
52
- if (t[2]) _.ops.pop();
53
- _.trys.pop(); continue;
54
- }
55
- op = body.call(thisArg, _);
56
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
57
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
58
- }
59
- };
60
- Object.defineProperty(exports, "__esModule", { value: true });
61
- exports.OAuth2AuthProvider = void 0;
62
- var base_1 = require("./base");
63
- var utilities_1 = require("@cloudbase/utilities/");
64
- var __1 = require("..");
65
- var constants_1 = require("../constants");
66
- var getSdkName = utilities_1.constants.getSdkName, ERRORS = utilities_1.constants.ERRORS, COMMUNITY_SITE_URL = utilities_1.constants.COMMUNITY_SITE_URL;
67
- var catchErrorsDecorator = utilities_1.helpers.catchErrorsDecorator;
68
- function qsParse(qs) {
69
- return qs.split('&').reduce(function (a, c) {
70
- var _a = c.split('='), key = _a[0], value = _a[1];
71
- a[key] = value;
72
- return a;
73
- }, {});
74
- }
75
- var kPaths = {
76
- prividerUri: '/auth/v1/provider/uri',
77
- prividerToken: '/auth/v1/provider/token',
78
- signinWithProvider: '/auth/v1/signin/with/provider',
79
- me: '/auth/v1/user/me',
80
- token: '/auth/v1/token',
81
- };
82
- var OAuth2AuthProvider = (function (_super) {
83
- __extends(OAuth2AuthProvider, _super);
84
- function OAuth2AuthProvider(config, options) {
85
- if (options === void 0) { options = {}; }
86
- var _this = _super.call(this, config) || this;
87
- _this.popupWindowRef = null;
88
- _this.providerId = options.providerId;
89
- _this.clientId = options.clientId || config.env;
90
- _this.responseType = options.responseType || 'token';
91
- _this.scope = options.scope || '';
92
- _this.redirectUri = options.redirectUri || '';
93
- _this.syncProfile = options.syncProfile || false;
94
- _this.forceDisableSignUp = options.forceDisableSignUp || false;
95
- var recvMessageFromPopup = _this.recvMessageFromPopup.bind(_this);
96
- window.removeEventListener('message', recvMessageFromPopup);
97
- window.addEventListener('message', recvMessageFromPopup, false);
98
- return _this;
99
- }
100
- OAuth2AuthProvider.prototype.signIn = function () {
101
- return __awaiter(this, void 0, void 0, function () {
102
- return __generator(this, function (_a) {
103
- return [2, utilities_1.utils.printWarn(ERRORS.OPERATION_FAIL, 'API signIn has been deprecated, please use signInWithRedirect insteed')];
104
- });
105
- });
106
- };
107
- OAuth2AuthProvider.prototype.signInWithPopup = function (options) {
108
- if (options === void 0) { options = {}; }
109
- return __awaiter(this, void 0, void 0, function () {
110
- return __generator(this, function (_a) {
111
- return [2, this.jumpToProviderPage(options)];
112
- });
113
- });
114
- };
115
- OAuth2AuthProvider.prototype.signInWithModal = function (elemId) {
116
- return __awaiter(this, void 0, void 0, function () {
117
- var authorize_uri, modal, style, html, script;
118
- return __generator(this, function (_a) {
119
- switch (_a.label) {
120
- case 0: return [4, this.fetchProviderRedirectURI()];
121
- case 1:
122
- authorize_uri = (_a.sent()).uri;
123
- modal = document.getElementById(elemId);
124
- modal.style.display = 'block';
125
- style = "\n <style>\n /* The Modal (background) */\n .modal {\n display: none; /* Hidden by default */\n position: fixed; /* Stay in place */\n z-index: 1; /* Sit on top */\n padding-top: 100px; /* Location of the box */\n left: 0;\n top: 0;\n width: 100%; /* Full width */\n height: 100%; /* Full height */\n overflow: auto; /* Enable scroll if needed */\n background-color: rgb(0,0,0); /* Fallback color */\n background-color: rgba(0,0,0,0.4); /* Black w/ opacity */\n }\n \n /* Modal Content */\n .modal-content {\n background-color: #fefefe;\n margin: auto;\n padding: 20px;\n border: 1px solid #888;\n /* width: 80%; */\n }\n \n /* The Close Button */\n .close {\n color: #aaaaaa;\n float: right;\n font-size: 28px;\n font-weight: bold;\n }\n .close:hover,\n .close:focus {\n color: #000;\n text-decoration: none;\n cursor: pointer;\n }\n </style>\n ";
126
- html = "\n <div class=\"modal-content\">\n <span class=\"close\">&times;</span>\n <iframe id=\"loginIframe\" src=\"" + authorize_uri + "\" title=\"iframe Example 1\" width=\"400\" height=\"300\"></iframe>\n </div>\n ";
127
- script = "\n <script>\n // Get the <span> element that closes the modal\n var span = document.getElementsByClassName(\"close\")[0];\n \n // When the user clicks on <span> (x), close the modal\n span.onclick = function() {\n modal.style.display = \"none\";\n }\n \n // When the user clicks anywhere outside of the modal, close it\n window.onclick = function(event) {\n if (event.target == modal) {\n modal.style.display = \"none\";\n }\n }\n\n const loginIframe = document.getElementById(\"loginIframe\")\n </script>\n ";
128
- modal.innerHTML = "\n " + html + "\n " + style + "\n " + script + "\n ";
129
- return [2];
130
- }
131
- });
132
- });
133
- };
134
- OAuth2AuthProvider.prototype.jumpToProviderPage = function (options) {
135
- if (options === void 0) { options = {}; }
136
- return __awaiter(this, void 0, void 0, function () {
137
- var authorize_uri, popup, popupWindowTarget, popupWindowFeatures, popupWindowRef, e_1;
138
- return __generator(this, function (_a) {
139
- switch (_a.label) {
140
- case 0:
141
- _a.trys.push([0, 2, , 3]);
142
- return [4, this.fetchProviderRedirectURI()];
143
- case 1:
144
- authorize_uri = (_a.sent()).uri;
145
- popup = options.popup || {};
146
- popupWindowTarget = popup.target || '_blank';
147
- popupWindowFeatures = popup.features || 'toolbar=no, menubar=no, width=600, height=700, top=100, left=100';
148
- popupWindowRef = this.popupWindowRef;
149
- if (popupWindowRef === null || popupWindowRef.closed) {
150
- popupWindowRef = window.open(authorize_uri, popupWindowTarget, popupWindowFeatures);
151
- }
152
- else if (this.popupWindowUrl !== authorize_uri) {
153
- if (popupWindowRef && !popupWindowRef.closed) {
154
- popupWindowRef.close();
155
- }
156
- popupWindowRef = window.open(authorize_uri, popupWindowTarget, popupWindowFeatures);
157
- }
158
- else {
159
- }
160
- if (!popupWindowRef) {
161
- return [2, utilities_1.utils.printWarn(ERRORS.OPERATION_FAIL, "\u6253\u5F00\u7B2C\u4E09\u65B9\u767B\u5F55\u6388\u6743\u5931\u8D25\uFF0C\u53EF\u80FD\u662F\u7981\u7528\u4E86\u6D4F\u89C8\u5668\u5F39\u7A97\uFF0Curi: " + authorize_uri)];
162
- }
163
- this.popupWindowUrl = authorize_uri;
164
- this.popupWindowRef = popupWindowRef;
165
- this.popupWindowRef.focus();
166
- return [3, 3];
167
- case 2:
168
- e_1 = _a.sent();
169
- if (this.popupWindowRef && !this.popupWindowRef.closed) {
170
- this.popupWindowRef.close();
171
- }
172
- throw new Error("[" + getSdkName() + "][" + ERRORS.UNKOWN_ERROR + "]" + e_1);
173
- case 3: return [2];
174
- }
175
- });
176
- });
177
- };
178
- OAuth2AuthProvider.prototype.recvMessageFromPopup = function (event) {
179
- if (!event.isTrusted) {
180
- return;
181
- }
182
- if (this.popupWindowRef === event.source && event.data.source === 'cloudbase-login-redirect') {
183
- var data = event.data;
184
- this.continueSignIn(data.callbackInfo);
185
- if (!this.popupWindowRef.closed) {
186
- this.popupWindowRef.close();
187
- }
188
- }
189
- };
190
- OAuth2AuthProvider.prototype.continueSignIn = function (callbackInfo) {
191
- return __awaiter(this, void 0, void 0, function () {
192
- var token, _a, accessTokenKey, accessTokenExpireKey, refreshTokenKey, refreshToken, accessToken, accessTokenExpire, loginState;
193
- return __generator(this, function (_b) {
194
- switch (_b.label) {
195
- case 0:
196
- callbackInfo = callbackInfo || this.getAuthPrividerCallbackInfoFromUrl();
197
- return [4, this.signInWithProvider(callbackInfo)];
198
- case 1:
199
- token = _b.sent();
200
- _a = this._cache.keys, accessTokenKey = _a.accessTokenKey, accessTokenExpireKey = _a.accessTokenExpireKey, refreshTokenKey = _a.refreshTokenKey;
201
- refreshToken = token.refresh_token, accessToken = token.access_token, accessTokenExpire = token.expires_in;
202
- if (!accessToken || !accessTokenExpire) {
203
- throw new Error(JSON.stringify({
204
- code: 'SignFailure'
205
- }));
206
- }
207
- return [4, Promise.all([
208
- this._cache.setStoreAsync(refreshTokenKey, refreshToken),
209
- this._cache.setStoreAsync(accessTokenKey, accessToken),
210
- this._cache.setStoreAsync(accessTokenExpireKey, accessTokenExpire * 1000 + Date.now())
211
- ])];
212
- case 2:
213
- _b.sent();
214
- __1.eventBus.fire(__1.EVENTS.LOGIN_STATE_CHANGED);
215
- __1.eventBus.fire(__1.EVENTS.LOGIN_TYPE_CHANGED, {
216
- env: this._config.env,
217
- loginType: constants_1.OAUTH2_LOGINTYPE_PREFIX + "." + this.providerId,
218
- persistence: this._config.persistence
219
- });
220
- loginState = new __1.LoginState({
221
- envId: this._config.env,
222
- cache: this._cache,
223
- request: this._request
224
- });
225
- return [4, loginState.checkLocalStateAsync()];
226
- case 3:
227
- _b.sent();
228
- return [2, loginState];
229
- }
230
- });
231
- });
232
- };
233
- OAuth2AuthProvider.prototype.getAuthPrividerCallbackInfoFromUrl = function () {
234
- return qsParse(decodeURIComponent((new URL(window.location.href).hash).replace('#', '')));
235
- };
236
- OAuth2AuthProvider.prototype.fetchProviderRedirectURI = function () {
237
- return __awaiter(this, void 0, void 0, function () {
238
- var _a, response_type, provider_id, client_id, scope, redirect_uri, state, qs, resp;
239
- return __generator(this, function (_b) {
240
- switch (_b.label) {
241
- case 0:
242
- _a = {
243
- response_type: this.responseType,
244
- provider_id: this.providerId,
245
- client_id: this.clientId,
246
- scope: this.scope,
247
- redirect_uri: this.redirectUri,
248
- state: btoa(JSON.stringify({
249
- t: Date.now(),
250
- provider_id: this.providerId,
251
- client_id: this.clientId,
252
- routeKey: ''
253
- })),
254
- }, response_type = _a.response_type, provider_id = _a.provider_id, client_id = _a.client_id, scope = _a.scope, redirect_uri = _a.redirect_uri, state = _a.state;
255
- qs = utilities_1.utils.toQueryString({
256
- response_type: response_type,
257
- provider_id: provider_id,
258
- client_id: client_id,
259
- scope: scope,
260
- redirect_uri: redirect_uri,
261
- state: state,
262
- });
263
- return [4, this.fetch(kPaths.prividerUri + "?" + qs, {
264
- method: 'GET'
265
- })];
266
- case 1:
267
- resp = _b.sent();
268
- return [2, resp.json()];
269
- }
270
- });
271
- });
272
- };
273
- OAuth2AuthProvider.prototype.fetchProviderToken = function (callbackInfo) {
274
- return __awaiter(this, void 0, void 0, function () {
275
- var body, resp;
276
- return __generator(this, function (_a) {
277
- switch (_a.label) {
278
- case 0:
279
- body = {
280
- provider_id: this.providerId,
281
- client_id: this.clientId,
282
- provider_redirect_uri: callbackInfo.href
283
- };
284
- if (callbackInfo.code) {
285
- body.provider_code = callbackInfo.code;
286
- }
287
- else if (callbackInfo.access_token) {
288
- body.provider_access_token = callbackInfo.access_token;
289
- }
290
- else if (callbackInfo.id_token) {
291
- body.provider_id_token = callbackInfo.id_token;
292
- }
293
- return [4, this.fetch(kPaths.prividerToken, {
294
- method: 'POST',
295
- headers: {
296
- 'Accept': 'application/json',
297
- 'Content-Type': 'application/json'
298
- },
299
- body: JSON.stringify(body)
300
- })];
301
- case 1:
302
- resp = _a.sent();
303
- return [2, resp.json()];
304
- }
305
- });
306
- });
307
- };
308
- OAuth2AuthProvider.prototype.signInWithProvider = function (callbackInfo) {
309
- return __awaiter(this, void 0, void 0, function () {
310
- var token, body, resp;
311
- return __generator(this, function (_a) {
312
- switch (_a.label) {
313
- case 0: return [4, this.fetchProviderToken(callbackInfo)];
314
- case 1:
315
- token = _a.sent();
316
- body = {
317
- client_id: this.clientId,
318
- provider_token: token.provider_token,
319
- sync_profile: this.syncProfile,
320
- force_disable_sign_up: this.forceDisableSignUp
321
- };
322
- return [4, this.fetch(kPaths.signinWithProvider, {
323
- method: 'POST',
324
- headers: {
325
- 'Accept': 'application/json',
326
- 'Content-Type': 'application/json'
327
- },
328
- body: JSON.stringify(body)
329
- })];
330
- case 2:
331
- resp = _a.sent();
332
- return [2, resp.json()];
333
- }
334
- });
335
- });
336
- };
337
- OAuth2AuthProvider.prototype.refreshUserInfo = function () {
338
- return __awaiter(this, void 0, void 0, function () {
339
- var accessToken, authorization, resp;
340
- return __generator(this, function (_a) {
341
- switch (_a.label) {
342
- case 0: return [4, this._request.getAccessToken()];
343
- case 1:
344
- accessToken = (_a.sent()).accessToken;
345
- authorization = "Bearer " + accessToken;
346
- return [4, this.fetch(kPaths.me, {
347
- method: 'GET',
348
- headers: {
349
- 'Accept': 'application/json',
350
- 'Content-Type': 'application/json',
351
- 'Authorization': authorization
352
- }
353
- })];
354
- case 2:
355
- resp = _a.sent();
356
- return [2, resp.json()];
357
- }
358
- });
359
- });
360
- };
361
- OAuth2AuthProvider.prototype.fetch = function (urlOrPath, init) {
362
- return __awaiter(this, void 0, void 0, function () {
363
- var resp, seqIdFromHeader, body, seqId, body, seqId;
364
- return __generator(this, function (_a) {
365
- switch (_a.label) {
366
- case 0: return [4, this._request.fetch(urlOrPath, init)];
367
- case 1:
368
- resp = _a.sent();
369
- seqIdFromHeader = resp.headers.get('SeqId') || resp.headers.get('RequestId');
370
- if (!(resp.status >= 400 && resp.status < 500)) return [3, 3];
371
- return [4, resp.json()];
372
- case 2:
373
- body = _a.sent();
374
- seqId = body.request_id || seqIdFromHeader;
375
- throw new Error("[" + getSdkName() + "][OAuth2AuthProvider][status:" + resp.status + "][" + body.error + "(" + body.error_code + ")] " + body.error_description + " (" + seqId + ")");
376
- case 3:
377
- if (!(resp.status >= 500)) return [3, 5];
378
- return [4, resp.json()];
379
- case 4:
380
- body = _a.sent();
381
- seqId = body.request_id || seqIdFromHeader;
382
- throw new Error("[" + getSdkName() + "][OAuth2AuthProvider][status:" + resp.status + "][" + body.error + "(" + body.error_code + ")] " + body.error_description + " (" + seqId + ")");
383
- case 5: return [2, resp];
384
- }
385
- });
386
- });
387
- };
388
- __decorate([
389
- catchErrorsDecorator({
390
- title: '跳转第三方登录平台失败',
391
- messages: [
392
- '请确认以下各项:',
393
- ' 1 - 调用 auth().oAuth2AuthProvider() 的参数是否正确',
394
- "\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A" + COMMUNITY_SITE_URL
395
- ]
396
- }),
397
- __metadata("design:type", Function),
398
- __metadata("design:paramtypes", [Object]),
399
- __metadata("design:returntype", Promise)
400
- ], OAuth2AuthProvider.prototype, "signInWithPopup", null);
401
- return OAuth2AuthProvider;
402
- }(base_1.AuthProvider));
403
- exports.OAuth2AuthProvider = OAuth2AuthProvider;
404
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2AuthProvider.js","sourceRoot":"","sources":["../../../src/providers/oauth2AuthProvider.ts"],"names":[],"mappings":"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","sourcesContent":["import { AuthProvider } from './base'\nimport { ICloudbaseAuthConfig } from '@cloudbase/types/auth'\nimport { ICloudbaseCache } from '@cloudbase/types/cache'\nimport { ICloudbaseRequest } from '@cloudbase/types/request'\nimport { constants, utils, helpers } from '@cloudbase/utilities/'\nimport { eventBus, EVENTS, LoginState } from '..'\nimport { OAUTH2_LOGINTYPE_PREFIX } from '../constants';\n\nconst { getSdkName, ERRORS, COMMUNITY_SITE_URL } = constants\nconst { catchErrorsDecorator } = helpers\n\nfunction qsParse(qs: string): object {\n  return qs.split('&').reduce((a, c) => {\n    const [key, value] = c.split('=')\n    a[key] = value\n    return a\n  }, {})\n}\n\nconst kPaths = {\n  prividerUri: '/auth/v1/provider/uri',\n  prividerToken: '/auth/v1/provider/token',\n  signinWithProvider: '/auth/v1/signin/with/provider',\n  me: '/auth/v1/user/me',\n  token: '/auth/v1/token',\n}\n\ninterface IGenProviderRedirectURIRequest {\n  response_type: string // token | code\n  provider_id: string // google github ...\n  client_id: string // \n  scope: string //\n  redirect_uri: string\n  state?: string\n  // other_params?: string\n}\n\ninterface IGenProviderRedirectURIResponse {\n  uri: string\n  signout_uri: string\n}\n\ninterface IGrantProviderTokenRequest {\n  provider_id: string\n  client_id: string\n\n  // 以下参数任选其一即可\n  provider_code?: string // 'provider_code'\n  provider_access_token?: string // 'provider_access_token'\n  provider_id_token?: string // 'provider_id_token'\n\n  provider_redirect_uri?: string\n  provider_params?: string // 'provider_params'\n}\n\ninterface IProviderProfile {\n  provider_id: string\n  // 主ID\n  sub?: string\n  name?: string\n  picture?: string\n  email?: string\n  phone_number?: string\n  gender?: string\n  locale?: string\n  // 三方信息原文\n  raw?: string\n  // 其他关联的ID\n  associated_ids?: string\n  meta?:  {\n    [key: string]: string\n  }\n}\n\ninterface IGrantProviderTokenResponse {\n  // 如果不启用自动注册， 则返回 provider_token， 用于进一步处理，例如：通过手机号等。\n  provider_token: string\n  // 过期时间\n  expires_in: number\n  // 如果不启用自动注册，则会返回provider userinfo end_point 的返回详情，用于前端展示\n  provider_profile: IProviderProfile\n}\n\ninterface ISignInWithProviderRequest {\n  client_id: string\n  provider_token: string\n  // 强制关闭自动注册。\n  // 默认情况下，这里以服务器配置为准，如果客户端为了平滑升级可以配置为true。\n  force_disable_sign_up: boolean\n  // 是否强制从第三方同步昵称等信息\n  sync_profile: boolean\n}\n\ninterface IToken {\n  token_type: string\n  access_token: string\n  refresh_token: string\n  id_token: string\n  expires_in: number\n  scope?: string\n  sub?: string\n  user_group?: string\n}\n\ninterface IPrividerCallbackInfo {\n  href: string,\n\n  state: string,\n\n  token_type: string,\n  code?: string,\n  access_token?: string,\n  id_token?: string,\n\n  expires_in: number,\n  scope: string,\n  authuser: string,\n  prompt: string\n}\n\ninterface IPopupWindowAuthRedirectMessage {\n  source: string,\n  callbackInfo: IPrividerCallbackInfo\n}\n\nexport interface IOAuth2AuthProviderOptions {\n  providerId?: string\n  clientId?: string\n  responseType?: string\n  scope?: string\n  redirectUri?: string\n\n  syncProfile?: boolean\n  forceDisableSignUp?: boolean\n}\n\nexport interface ISignInWithPopupOptions {\n  popup?: {\n    target?: string,\n    features?: string\n  }\n}\n\ninterface IAuthServerRespError {\n  error: string,\n  error_code: number,\n  error_description: string\n  request_id: string\n}\n\nexport class OAuth2AuthProvider extends AuthProvider {\n  // private readonly _scope: string\n  // private readonly _state: string\n  // private readonly _appid: string\n  // private readonly _runtime: string\n\n  private providerId: string\n  private clientId: string\n  private responseType: string\n  private scope: string\n  private redirectUri: string\n  private syncProfile: boolean\n  private forceDisableSignUp: boolean\n\n  private popupWindowUrl: string\n  private popupWindowRef: Window = null\n\n  constructor(config: ICloudbaseAuthConfig&{cache:ICloudbaseCache,request:ICloudbaseRequest,runtime:string}, options: IOAuth2AuthProviderOptions = {}) {\n    super(config)\n\n    this.providerId = options.providerId\n    this.clientId = options.clientId || config.env\n    this.responseType = options.responseType || 'token'\n    this.scope = options.scope || ''\n    this.redirectUri = options.redirectUri || ''\n    this.syncProfile = options.syncProfile || false\n    this.forceDisableSignUp = options.forceDisableSignUp || false\n\n    const recvMessageFromPopup = this.recvMessageFromPopup.bind(this)\n    window.removeEventListener('message', recvMessageFromPopup)\n    window.addEventListener('message', recvMessageFromPopup, false)\n  }\n\n  public async signIn(){\n    return utils.printWarn(ERRORS.OPERATION_FAIL, 'API signIn has been deprecated, please use signInWithRedirect insteed')\n  }\n\n  @catchErrorsDecorator({\n    title: '跳转第三方登录平台失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().oAuth2AuthProvider() 的参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`\n    ]\n  })\n  public async signInWithPopup(options: ISignInWithPopupOptions = {}) {\n    // if (this.checkLocalLoginState()) {\n    //   throw new Error(`[${getSdkName()}][${ERRORS.UNKOWN_ERROR}]已登录，请先退出`)\n    // }\n    return this.jumpToProviderPage(options)\n  }\n\n  public async signInWithModal(elemId: string) {\n\n    const { uri: authorize_uri } = await this.fetchProviderRedirectURI()\n    const modal = document.getElementById(elemId)\n    modal.style.display = 'block'\n    const style = `\n    <style>\n      /* The Modal (background) */\n      .modal {\n        display: none; /* Hidden by default */\n        position: fixed; /* Stay in place */\n        z-index: 1; /* Sit on top */\n        padding-top: 100px; /* Location of the box */\n        left: 0;\n        top: 0;\n        width: 100%; /* Full width */\n        height: 100%; /* Full height */\n        overflow: auto; /* Enable scroll if needed */\n        background-color: rgb(0,0,0); /* Fallback color */\n        background-color: rgba(0,0,0,0.4); /* Black w/ opacity */\n      }\n  \n      /* Modal Content */\n      .modal-content {\n        background-color: #fefefe;\n        margin: auto;\n        padding: 20px;\n        border: 1px solid #888;\n        /* width: 80%; */\n      }\n  \n      /* The Close Button */\n      .close {\n        color: #aaaaaa;\n        float: right;\n        font-size: 28px;\n        font-weight: bold;\n      }\n      .close:hover,\n      .close:focus {\n        color: #000;\n        text-decoration: none;\n        cursor: pointer;\n      }\n      </style>\n    `\n    const html = `\n      <div class=\"modal-content\">\n        <span class=\"close\">&times;</span>\n        <iframe id=\"loginIframe\" src=\"${authorize_uri}\" title=\"iframe Example 1\" width=\"400\" height=\"300\"></iframe>\n      </div>\n    `\n    const script = `\n      <script>\n      // Get the <span> element that closes the modal\n      var span = document.getElementsByClassName(\"close\")[0];\n      \n      // When the user clicks on <span> (x), close the modal\n      span.onclick = function() {\n        modal.style.display = \"none\";\n      }\n  \n      // When the user clicks anywhere outside of the modal, close it\n      window.onclick = function(event) {\n        if (event.target == modal) {\n          modal.style.display = \"none\";\n        }\n      }\n\n      const loginIframe = document.getElementById(\"loginIframe\")\n      </script>\n    `\n    modal.innerHTML = `\n      ${html}\n      ${style}\n      ${script}\n    `\n  }\n\n  private async jumpToProviderPage(options: ISignInWithPopupOptions = {}): Promise<void> {\n    try {\n      const { uri: authorize_uri } = await this.fetchProviderRedirectURI()\n      const popup = options.popup || {}\n      const popupWindowTarget = popup.target || '_blank'\n      const popupWindowFeatures = popup.features || 'toolbar=no, menubar=no, width=600, height=700, top=100, left=100'\n      // console.log('jumpToProviderPage: ', authorize_uri, this.popupWindowRef)\n      let popupWindowRef = this.popupWindowRef\n      if (popupWindowRef === null || popupWindowRef.closed) {\n        popupWindowRef = window.open(authorize_uri, popupWindowTarget, popupWindowFeatures)\n      } else if (this.popupWindowUrl !== authorize_uri) {\n        if (popupWindowRef && !popupWindowRef.closed) {\n          popupWindowRef.close()\n        }\n        popupWindowRef = window.open(authorize_uri, popupWindowTarget, popupWindowFeatures)\n      } else {\n        // popupWindowRef.focus()\n      }\n\n      if (!popupWindowRef) {\n        return utils.printWarn(ERRORS.OPERATION_FAIL, `打开第三方登录授权失败，可能是禁用了浏览器弹窗，uri: ${authorize_uri}`)\n      }\n      this.popupWindowUrl = authorize_uri\n      this.popupWindowRef = popupWindowRef\n      this.popupWindowRef.focus()\n    } catch(e) {\n      // DOMException: Blocked a frame with origin \"\" from accessing a cross-origin frame.\n      if (this.popupWindowRef && !this.popupWindowRef.closed) {\n        this.popupWindowRef.close()\n      }\n      throw new Error(`[${getSdkName()}][${ERRORS.UNKOWN_ERROR}]${e}`)\n    }\n\n    // 在新标签页 post message 进行测试，或取消注释进行测试\n    // window.opener.postMessage\n    // this.popupWindowRef.postMessage({\n    //   source: 'cloudbase-login-redirect',\n    //   callbackInfo: {\n    //     state: 'eyJ0IjoxNjI3ODI4MzA2MjQzLCJwcm92aWRlcl9pZCI6Imdvb2dsZSIsImNsaWVudF9pZCI6InByb2R1Y3Rpb24tZnY5NzkiLCJyb3V0ZUtleSI6IiJ9',\n    //     access_token: 'ya29.a0ARrdaM_JF-7l1aNkssC-jRYIDEoEyU2Rngkjoy0s9lHAAJp56yuxEyoUa8saDhR1S-04xtraEmDc0QSokyBOSVpKIE5zP0skeMWZuZinwmKhbsQTZfrCGJJGQM8n72HEhaxqK17k-gBd2MN0bWf9i-dlHnJECQ',\n    //     token_type: 'Bearer',\n    //     expires_in: '3598',\n    //     scope: 'email%20profile%20openid%20https://www.googleapis.com/auth/userinfo.profile%20https://www.googleapis.com/auth/userinfo.email',\n    //     authuser: '0',\n    //     prompt: 'none'\n    //   }\n    // }, 'http:///')\n\n    // function postMessageToOpener() {\n    //   // 需要支持不同的参数形式\n    //   if (window.opener) {\n    //     // window.opener.postMessage({\n    //     //   source: 'cloudbase-login-redirect',\n    //     //   redirectUri: '',\n    //     //   callbackInfo: {\n    //     //     state: 'eyJ0IjoxNjI3NjMwNTY4NjkzLCJwcm92aWRlcl9pZCI6Imdvb2dsZSIsImNsaWVudF9pZCI6InByb2R1Y3Rpb24tZnY5NzkifQ==',\n    //     //     access_token: 'ya29.a0ARrdaM-hLc_CAGF26xMjTzdlAloRs8WihWFVy6GRDGv1DMYZbG0k1xI3dKgu3E42Gi6P1D1V6dtz-XBShjDou2MRWNaPNZ_SNC_idRTIqTCxU1f7xU-FKfmS8A0AZZDk8-h7a3VYsh12Eei1j2UNwuDGKUuOPw',\n    //     //     token_type: 'Bearer',\n    //     //     expires_in: '3599',\n    //     //     scope: 'email%20profile%20openid%20https://www.googleapis.com/auth/userinfo.email%20https://www.googleapis.com/auth/userinfo.profile',\n    //     //     authuser: '0',\n    //     //     prompt: 'none'\n    //     //   }\n    //     // }, 'http:///')\n    //     const params = window.location.search\n    //     window.opener.postMessage(params, '')\n    //     window.close()\n    //   }\n    // }\n  }\n\n  /**\n   * recvMessageFromPopup 接收回调页面登录消息\n   * @param event\n   * @returns \n   */\n  private recvMessageFromPopup(event: MessageEvent) {\n    // console.log('recv event:', event)\n    // origin: \"http:///\"\n    if (!event.isTrusted) {\n      // console.log('!event.isTrusted')\n      return\n    }\n    // console.log('this.popupWindowRef === event.source', this.popupWindowRef === event.source)\n    if (this.popupWindowRef === event.source && event.data.source === 'cloudbase-login-redirect') {\n      // console.log('recv cloudbase-login-redirect event', event.data)\n      const data: IPopupWindowAuthRedirectMessage = event.data\n      this.continueSignIn(data.callbackInfo)\n      if (!this.popupWindowRef.closed) {\n        this.popupWindowRef.close()\n      }\n    }\n  }\n\n  /**\n   * continueSignIn 继续登录\n   * @param callbackInfo\n   * @returns\n   */\n  async continueSignIn(callbackInfo?: IPrividerCallbackInfo): Promise<LoginState> {\n    // 这里支持在回调页面调用该函数完成登录\n    callbackInfo = callbackInfo || this.getAuthPrividerCallbackInfoFromUrl()\n    const token = await this.signInWithProvider(callbackInfo)\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys\n    const { refresh_token: refreshToken, access_token: accessToken, expires_in: accessTokenExpire } = token\n\n    if (!accessToken || !accessTokenExpire) {\n      throw new Error(JSON.stringify({\n        code: 'SignFailure'\n      }))\n    }\n\n    await Promise.all([\n      this._cache.setStoreAsync(refreshTokenKey, refreshToken),\n      this._cache.setStoreAsync(accessTokenKey, accessToken),\n      this._cache.setStoreAsync(accessTokenExpireKey, accessTokenExpire * 1000 + Date.now())\n    ])\n    eventBus.fire(EVENTS.LOGIN_STATE_CHANGED)\n    eventBus.fire(EVENTS.LOGIN_TYPE_CHANGED, {\n      env: this._config.env,\n      loginType: `${OAUTH2_LOGINTYPE_PREFIX}.${this.providerId}`, \n      persistence: this._config.persistence \n    })\n\n    const loginState = new LoginState({\n      envId: this._config.env,\n      cache: this._cache,\n      request: this._request\n    })\n\n    await loginState.checkLocalStateAsync()\n\n    // const userInfo = await this.refreshUserInfo()\n\n    return loginState\n  }\n\n  private getAuthPrividerCallbackInfoFromUrl(): IPrividerCallbackInfo {\n    // TODO: 支持 Query & Hash\n    // 直接从 URL 上取回调信息\n    // {\n    //   state: '_tstate.1627564561750',\n    //   access_token: 'ya29.a0ARrdaM98yMpUhCJRq2lVezPtdhQHAWsvDzj5OiiI8WREawQjC9HUo7tKjusJR4z0OCD5435BtbqH-kTsLTB3nllfHL0GjqJN1N20_r8Qs2ckVwH7axCuokmw58A_d0SKVuqN-U-NR61QrIK6Hvl8WAM-jm22ew',\n    //   token_type: 'Bearer',\n    //   expires_in: 3599,\n    //   scope: 'email%20profile%20openid%20https://www.googleapis.com/auth/userinfo.email%20https://www.googleapis.com/auth/userinfo.profile',\n    //   authuser: '0',\n    //   prompt: 'none'\n    // }\n    return qsParse(decodeURIComponent((new URL(window.location.href).hash).replace('#', ''))) as IPrividerCallbackInfo\n  }\n\n  private async fetchProviderRedirectURI(): Promise<IGenProviderRedirectURIResponse> {\n    const {\n      response_type,\n      provider_id,\n      client_id,\n      scope,\n      redirect_uri,\n      state,\n      // other_params\n    }: IGenProviderRedirectURIRequest = {\n      response_type: this.responseType,\n      provider_id: this.providerId,\n      client_id: this.clientId,\n      scope: this.scope,\n      redirect_uri: this.redirectUri,\n      state: btoa(JSON.stringify({\n        t: Date.now(),\n        provider_id: this.providerId,\n        client_id: this.clientId,\n        // 登录成功之后路由的页面地址\n        routeKey: ''\n      })),\n      // other_params: utils.toQueryString({ a: 1 })\n    }\n\n    const qs = utils.toQueryString({\n      response_type,\n      provider_id,\n      client_id,\n      scope,\n      redirect_uri,\n      state,\n      // other_params\n    })\n    const resp = await this.fetch(`${kPaths.prividerUri}?${qs}`, {\n      method: 'GET'\n    })\n    // {\n    //   uri: 'https://accounts.google.com/o/oauth2/v2/auth?client_id=686970215944-gun1neofjhtjt7gmta2qfth6f82sj011.apps.googleusercontent.com&redirect_uri=https%3A%2F%2Fproduction-fv979-1258964769.ap-shanghai.app.tcloudbase.com&response_type=token&scope=openid+email+profile&state=_tstate.1627545941923',\n    //   signout_uri: ''\n    // }\n    return resp.json()\n  }\n\n  private async fetchProviderToken(callbackInfo: IPrividerCallbackInfo): Promise<IGrantProviderTokenResponse> {\n    // const state = atob(JSON.stringify(callbackInfo.state))\n    const body: IGrantProviderTokenRequest = {\n      provider_id: this.providerId,\n      client_id: this.clientId,\n      provider_redirect_uri: callbackInfo.href\n    }\n\n    if (callbackInfo.code) {\n      body.provider_code = callbackInfo.code\n    }\n    else if (callbackInfo.access_token) {\n      body.provider_access_token = callbackInfo.access_token\n    }\n    else if (callbackInfo.id_token) {\n      body.provider_id_token = callbackInfo.id_token\n    }\n\n    const resp = await this.fetch(kPaths.prividerToken, {\n      method: 'POST',\n      headers: {\n        'Accept': 'application/json',\n        'Content-Type': 'application/json'\n      },\n      body: JSON.stringify(body)\n    })\n    // {\n    //   \"provider_token\": \"eyJhbGciOiJB6AS8......HB4-v1P1j-zwqiQ\",\n    //   \"expires_in\": 1200,\n    //   \"provider_profile\": {\n    //     \"provider_id\": \"google\",\n    //     \"sub\": \"101963751496807079381\",\n    //     \"name\": \"\",\n    //     \"picture\": \"\",\n    //     \"email\": \"\",\n    //     \"locale\": \"zh-cn\"\n    //   }\n    // }\n    return resp.json()\n  }\n\n  private async signInWithProvider(callbackInfo: IPrividerCallbackInfo): Promise<IToken> {\n    const token = await this.fetchProviderToken(callbackInfo)\n    const body: ISignInWithProviderRequest = {\n      client_id: this.clientId,\n      provider_token: token.provider_token,\n      sync_profile: this.syncProfile,\n      force_disable_sign_up: this.forceDisableSignUp\n    }\n    const resp = await this.fetch(kPaths.signinWithProvider, {\n      method: 'POST',\n      headers: {\n        'Accept': 'application/json',\n        'Content-Type': 'application/json'\n      },\n      body: JSON.stringify(body)\n    })\n    return resp.json()\n  }\n\n  async refreshUserInfo() {\n    const { accessToken } = (await this._request.getAccessToken())\n    const authorization = `Bearer ${accessToken}`\n    const resp = await this.fetch(kPaths.me, {\n      method: 'GET',\n      headers: {\n        'Accept': 'application/json',\n        'Content-Type': 'application/json',\n        'Authorization': authorization\n      }\n    })\n    // {\n    //   \"sub\": \"7aab4ba9053e4402a3d42b61cc257c11\",\n    //   \"name\": \"\",\n    //   \"picture\": \"https://lh3.googleusercontent.com/a-/AOh14Gg4sDe14SC5WNs85Ko2nfBlXvldYVgbSYbvIrka=s96-c\",\n    //   \"email\": \"\",\n    //   \"providers\": [\n    //     {\n    //       \"id\": \"google\",\n    //       \"provider_user_id\": \"101963751496807079381\",\n    //       \"name\": \"\"\n    //     }\n    //   ],\n    //   \"status\": \"ACTIVE\",\n    //   \"created_at\": \"2021-07-28T06:31:36.983Z\",\n    //   \"password_updated_at\": \"2021-07-28T06:31:36.983Z\"\n    // }\n    return resp.json()\n  }\n\n  private async fetch(urlOrPath: string, init?: RequestInit) {\n    const resp = await this._request.fetch(urlOrPath, init)\n\n    const seqIdFromHeader = resp.headers.get('SeqId') || resp.headers.get('RequestId')\n    if (resp.status >= 400 && resp.status < 500) {\n      const body: IAuthServerRespError = await resp.json()\n      const seqId = body.request_id || seqIdFromHeader\n      throw new Error(`[${getSdkName()}][OAuth2AuthProvider][status:${resp.status}][${body.error}(${body.error_code})] ${body.error_description} (${seqId})`)\n    }\n    else if (resp.status >= 500) {\n      const body: IAuthServerRespError = await resp.json()\n      const seqId = body.request_id || seqIdFromHeader\n      throw new Error(`[${getSdkName()}][OAuth2AuthProvider][status:${resp.status}][${body.error}(${body.error_code})] ${body.error_description} (${seqId})`)\n    }\n\n    return resp\n  }\n}\n"]}
@@ -1,17 +0,0 @@
1
- import { ILoginState } from '@cloudbase/types/auth';
2
- import { AuthProvider } from './base';
3
- export declare const SIGN_METHOD: {
4
- SIGNIN: string;
5
- SIGNUP: string;
6
- FORCERESETPWD: string;
7
- };
8
- export declare class PhoneAuthProvider extends AuthProvider {
9
- signIn(param: {
10
- phoneNumber: string;
11
- phoneCode?: string;
12
- password?: string;
13
- signMethod?: string;
14
- }): Promise<ILoginState>;
15
- signUp(phoneNumber: string, phoneCode: string, password?: string): Promise<ILoginState>;
16
- forceResetPwd(phoneNumber: string, phoneCode: string, password: string): Promise<ILoginState>;
17
- }