@cloudbase/auth 1.7.3-alpha.0 → 2.0.0-alpha.3
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/dist/cjs/index.d.ts +53 -101
- package/dist/cjs/index.js +431 -773
- package/dist/esm/index.d.ts +53 -101
- package/dist/esm/index.js +432 -770
- package/package.json +52 -54
- package/src/index.ts +409 -767
- package/dist/cjs/common.d.ts +0 -8
- package/dist/cjs/common.js +0 -64
- package/dist/cjs/constants.d.ts +0 -12
- package/dist/cjs/constants.js +0 -17
- package/dist/cjs/providers/anonymousAuthProvider.d.ts +0 -15
- package/dist/cjs/providers/anonymousAuthProvider.js +0 -256
- package/dist/cjs/providers/base.d.ts +0 -21
- package/dist/cjs/providers/base.js +0 -152
- package/dist/cjs/providers/customAuthProvider.d.ts +0 -5
- package/dist/cjs/providers/customAuthProvider.js +0 -150
- package/dist/cjs/providers/emailAuthProvider.d.ts +0 -9
- package/dist/cjs/providers/emailAuthProvider.js +0 -250
- package/dist/cjs/providers/oauth2AuthProvider.d.ts +0 -61
- package/dist/cjs/providers/oauth2AuthProvider.js +0 -404
- package/dist/cjs/providers/phoneAuthProvider.d.ts +0 -17
- package/dist/cjs/providers/phoneAuthProvider.js +0 -219
- package/dist/cjs/providers/usernameAuthProvider.d.ts +0 -5
- package/dist/cjs/providers/usernameAuthProvider.js +0 -169
- package/dist/cjs/providers/weixinAuthProvider.d.ts +0 -28
- package/dist/cjs/providers/weixinAuthProvider.js +0 -294
- package/dist/esm/common.d.ts +0 -8
- package/dist/esm/common.js +0 -61
- package/dist/esm/constants.d.ts +0 -12
- package/dist/esm/constants.js +0 -14
- package/dist/esm/providers/anonymousAuthProvider.d.ts +0 -15
- package/dist/esm/providers/anonymousAuthProvider.js +0 -253
- package/dist/esm/providers/base.d.ts +0 -21
- package/dist/esm/providers/base.js +0 -149
- package/dist/esm/providers/customAuthProvider.d.ts +0 -5
- package/dist/esm/providers/customAuthProvider.js +0 -147
- package/dist/esm/providers/emailAuthProvider.d.ts +0 -9
- package/dist/esm/providers/emailAuthProvider.js +0 -247
- package/dist/esm/providers/oauth2AuthProvider.d.ts +0 -61
- package/dist/esm/providers/oauth2AuthProvider.js +0 -401
- package/dist/esm/providers/phoneAuthProvider.d.ts +0 -17
- package/dist/esm/providers/phoneAuthProvider.js +0 -216
- package/dist/esm/providers/usernameAuthProvider.d.ts +0 -5
- package/dist/esm/providers/usernameAuthProvider.js +0 -166
- package/dist/esm/providers/weixinAuthProvider.d.ts +0 -28
- package/dist/esm/providers/weixinAuthProvider.js +0 -291
- package/src/common.ts +0 -21
- package/src/constants.ts +0 -13
- package/src/providers/anonymousAuthProvider.ts +0 -126
- package/src/providers/base.ts +0 -78
- package/src/providers/customAuthProvider.ts +0 -69
- package/src/providers/emailAuthProvider.ts +0 -142
- package/src/providers/oauth2AuthProvider.ts +0 -585
- package/src/providers/phoneAuthProvider.ts +0 -132
- package/src/providers/usernameAuthProvider.ts +0 -77
- package/src/providers/weixinAuthProvider.ts +0 -193
|
@@ -1,401 +0,0 @@
|
|
|
1
|
-
var __extends = (this && this.__extends) || (function () {
|
|
2
|
-
var extendStatics = function (d, b) {
|
|
3
|
-
extendStatics = Object.setPrototypeOf ||
|
|
4
|
-
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
-
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
|
|
6
|
-
return extendStatics(d, b);
|
|
7
|
-
};
|
|
8
|
-
return function (d, b) {
|
|
9
|
-
extendStatics(d, b);
|
|
10
|
-
function __() { this.constructor = d; }
|
|
11
|
-
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
12
|
-
};
|
|
13
|
-
})();
|
|
14
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
15
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
16
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
17
|
-
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;
|
|
18
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
19
|
-
};
|
|
20
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
21
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
22
|
-
};
|
|
23
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
24
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
25
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
26
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
27
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
28
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
29
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
30
|
-
});
|
|
31
|
-
};
|
|
32
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
33
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
34
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
35
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
36
|
-
function step(op) {
|
|
37
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
38
|
-
while (_) try {
|
|
39
|
-
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;
|
|
40
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
41
|
-
switch (op[0]) {
|
|
42
|
-
case 0: case 1: t = op; break;
|
|
43
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
44
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
45
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
46
|
-
default:
|
|
47
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
48
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
49
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
50
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
51
|
-
if (t[2]) _.ops.pop();
|
|
52
|
-
_.trys.pop(); continue;
|
|
53
|
-
}
|
|
54
|
-
op = body.call(thisArg, _);
|
|
55
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
56
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
import { AuthProvider } from './base';
|
|
60
|
-
import { constants, utils, helpers } from '@cloudbase/utilities/';
|
|
61
|
-
import { eventBus, EVENTS, LoginState } from '..';
|
|
62
|
-
import { OAUTH2_LOGINTYPE_PREFIX } from '../constants';
|
|
63
|
-
var getSdkName = constants.getSdkName, ERRORS = constants.ERRORS, COMMUNITY_SITE_URL = constants.COMMUNITY_SITE_URL;
|
|
64
|
-
var catchErrorsDecorator = helpers.catchErrorsDecorator;
|
|
65
|
-
function qsParse(qs) {
|
|
66
|
-
return qs.split('&').reduce(function (a, c) {
|
|
67
|
-
var _a = c.split('='), key = _a[0], value = _a[1];
|
|
68
|
-
a[key] = value;
|
|
69
|
-
return a;
|
|
70
|
-
}, {});
|
|
71
|
-
}
|
|
72
|
-
var kPaths = {
|
|
73
|
-
prividerUri: '/auth/v1/provider/uri',
|
|
74
|
-
prividerToken: '/auth/v1/provider/token',
|
|
75
|
-
signinWithProvider: '/auth/v1/signin/with/provider',
|
|
76
|
-
me: '/auth/v1/user/me',
|
|
77
|
-
token: '/auth/v1/token',
|
|
78
|
-
};
|
|
79
|
-
var OAuth2AuthProvider = (function (_super) {
|
|
80
|
-
__extends(OAuth2AuthProvider, _super);
|
|
81
|
-
function OAuth2AuthProvider(config, options) {
|
|
82
|
-
if (options === void 0) { options = {}; }
|
|
83
|
-
var _this = _super.call(this, config) || this;
|
|
84
|
-
_this.popupWindowRef = null;
|
|
85
|
-
_this.providerId = options.providerId;
|
|
86
|
-
_this.clientId = options.clientId || config.env;
|
|
87
|
-
_this.responseType = options.responseType || 'token';
|
|
88
|
-
_this.scope = options.scope || '';
|
|
89
|
-
_this.redirectUri = options.redirectUri || '';
|
|
90
|
-
_this.syncProfile = options.syncProfile || false;
|
|
91
|
-
_this.forceDisableSignUp = options.forceDisableSignUp || false;
|
|
92
|
-
var recvMessageFromPopup = _this.recvMessageFromPopup.bind(_this);
|
|
93
|
-
window.removeEventListener('message', recvMessageFromPopup);
|
|
94
|
-
window.addEventListener('message', recvMessageFromPopup, false);
|
|
95
|
-
return _this;
|
|
96
|
-
}
|
|
97
|
-
OAuth2AuthProvider.prototype.signIn = function () {
|
|
98
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
99
|
-
return __generator(this, function (_a) {
|
|
100
|
-
return [2, utils.printWarn(ERRORS.OPERATION_FAIL, 'API signIn has been deprecated, please use signInWithRedirect insteed')];
|
|
101
|
-
});
|
|
102
|
-
});
|
|
103
|
-
};
|
|
104
|
-
OAuth2AuthProvider.prototype.signInWithPopup = function (options) {
|
|
105
|
-
if (options === void 0) { options = {}; }
|
|
106
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
107
|
-
return __generator(this, function (_a) {
|
|
108
|
-
return [2, this.jumpToProviderPage(options)];
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
};
|
|
112
|
-
OAuth2AuthProvider.prototype.signInWithModal = function (elemId) {
|
|
113
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
114
|
-
var authorize_uri, modal, style, html, script;
|
|
115
|
-
return __generator(this, function (_a) {
|
|
116
|
-
switch (_a.label) {
|
|
117
|
-
case 0: return [4, this.fetchProviderRedirectURI()];
|
|
118
|
-
case 1:
|
|
119
|
-
authorize_uri = (_a.sent()).uri;
|
|
120
|
-
modal = document.getElementById(elemId);
|
|
121
|
-
modal.style.display = 'block';
|
|
122
|
-
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 ";
|
|
123
|
-
html = "\n <div class=\"modal-content\">\n <span class=\"close\">×</span>\n <iframe id=\"loginIframe\" src=\"" + authorize_uri + "\" title=\"iframe Example 1\" width=\"400\" height=\"300\"></iframe>\n </div>\n ";
|
|
124
|
-
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 ";
|
|
125
|
-
modal.innerHTML = "\n " + html + "\n " + style + "\n " + script + "\n ";
|
|
126
|
-
return [2];
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
};
|
|
131
|
-
OAuth2AuthProvider.prototype.jumpToProviderPage = function (options) {
|
|
132
|
-
if (options === void 0) { options = {}; }
|
|
133
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
134
|
-
var authorize_uri, popup, popupWindowTarget, popupWindowFeatures, popupWindowRef, e_1;
|
|
135
|
-
return __generator(this, function (_a) {
|
|
136
|
-
switch (_a.label) {
|
|
137
|
-
case 0:
|
|
138
|
-
_a.trys.push([0, 2, , 3]);
|
|
139
|
-
return [4, this.fetchProviderRedirectURI()];
|
|
140
|
-
case 1:
|
|
141
|
-
authorize_uri = (_a.sent()).uri;
|
|
142
|
-
popup = options.popup || {};
|
|
143
|
-
popupWindowTarget = popup.target || '_blank';
|
|
144
|
-
popupWindowFeatures = popup.features || 'toolbar=no, menubar=no, width=600, height=700, top=100, left=100';
|
|
145
|
-
popupWindowRef = this.popupWindowRef;
|
|
146
|
-
if (popupWindowRef === null || popupWindowRef.closed) {
|
|
147
|
-
popupWindowRef = window.open(authorize_uri, popupWindowTarget, popupWindowFeatures);
|
|
148
|
-
}
|
|
149
|
-
else if (this.popupWindowUrl !== authorize_uri) {
|
|
150
|
-
if (popupWindowRef && !popupWindowRef.closed) {
|
|
151
|
-
popupWindowRef.close();
|
|
152
|
-
}
|
|
153
|
-
popupWindowRef = window.open(authorize_uri, popupWindowTarget, popupWindowFeatures);
|
|
154
|
-
}
|
|
155
|
-
else {
|
|
156
|
-
}
|
|
157
|
-
if (!popupWindowRef) {
|
|
158
|
-
return [2, 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)];
|
|
159
|
-
}
|
|
160
|
-
this.popupWindowUrl = authorize_uri;
|
|
161
|
-
this.popupWindowRef = popupWindowRef;
|
|
162
|
-
this.popupWindowRef.focus();
|
|
163
|
-
return [3, 3];
|
|
164
|
-
case 2:
|
|
165
|
-
e_1 = _a.sent();
|
|
166
|
-
if (this.popupWindowRef && !this.popupWindowRef.closed) {
|
|
167
|
-
this.popupWindowRef.close();
|
|
168
|
-
}
|
|
169
|
-
throw new Error("[" + getSdkName() + "][" + ERRORS.UNKOWN_ERROR + "]" + e_1);
|
|
170
|
-
case 3: return [2];
|
|
171
|
-
}
|
|
172
|
-
});
|
|
173
|
-
});
|
|
174
|
-
};
|
|
175
|
-
OAuth2AuthProvider.prototype.recvMessageFromPopup = function (event) {
|
|
176
|
-
if (!event.isTrusted) {
|
|
177
|
-
return;
|
|
178
|
-
}
|
|
179
|
-
if (this.popupWindowRef === event.source && event.data.source === 'cloudbase-login-redirect') {
|
|
180
|
-
var data = event.data;
|
|
181
|
-
this.continueSignIn(data.callbackInfo);
|
|
182
|
-
if (!this.popupWindowRef.closed) {
|
|
183
|
-
this.popupWindowRef.close();
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
};
|
|
187
|
-
OAuth2AuthProvider.prototype.continueSignIn = function (callbackInfo) {
|
|
188
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
189
|
-
var token, _a, accessTokenKey, accessTokenExpireKey, refreshTokenKey, refreshToken, accessToken, accessTokenExpire, loginState;
|
|
190
|
-
return __generator(this, function (_b) {
|
|
191
|
-
switch (_b.label) {
|
|
192
|
-
case 0:
|
|
193
|
-
callbackInfo = callbackInfo || this.getAuthPrividerCallbackInfoFromUrl();
|
|
194
|
-
return [4, this.signInWithProvider(callbackInfo)];
|
|
195
|
-
case 1:
|
|
196
|
-
token = _b.sent();
|
|
197
|
-
_a = this._cache.keys, accessTokenKey = _a.accessTokenKey, accessTokenExpireKey = _a.accessTokenExpireKey, refreshTokenKey = _a.refreshTokenKey;
|
|
198
|
-
refreshToken = token.refresh_token, accessToken = token.access_token, accessTokenExpire = token.expires_in;
|
|
199
|
-
if (!accessToken || !accessTokenExpire) {
|
|
200
|
-
throw new Error(JSON.stringify({
|
|
201
|
-
code: 'SignFailure'
|
|
202
|
-
}));
|
|
203
|
-
}
|
|
204
|
-
return [4, Promise.all([
|
|
205
|
-
this._cache.setStoreAsync(refreshTokenKey, refreshToken),
|
|
206
|
-
this._cache.setStoreAsync(accessTokenKey, accessToken),
|
|
207
|
-
this._cache.setStoreAsync(accessTokenExpireKey, accessTokenExpire * 1000 + Date.now())
|
|
208
|
-
])];
|
|
209
|
-
case 2:
|
|
210
|
-
_b.sent();
|
|
211
|
-
eventBus.fire(EVENTS.LOGIN_STATE_CHANGED);
|
|
212
|
-
eventBus.fire(EVENTS.LOGIN_TYPE_CHANGED, {
|
|
213
|
-
env: this._config.env,
|
|
214
|
-
loginType: OAUTH2_LOGINTYPE_PREFIX + "." + this.providerId,
|
|
215
|
-
persistence: this._config.persistence
|
|
216
|
-
});
|
|
217
|
-
loginState = new LoginState({
|
|
218
|
-
envId: this._config.env,
|
|
219
|
-
cache: this._cache,
|
|
220
|
-
request: this._request
|
|
221
|
-
});
|
|
222
|
-
return [4, loginState.checkLocalStateAsync()];
|
|
223
|
-
case 3:
|
|
224
|
-
_b.sent();
|
|
225
|
-
return [2, loginState];
|
|
226
|
-
}
|
|
227
|
-
});
|
|
228
|
-
});
|
|
229
|
-
};
|
|
230
|
-
OAuth2AuthProvider.prototype.getAuthPrividerCallbackInfoFromUrl = function () {
|
|
231
|
-
return qsParse(decodeURIComponent((new URL(window.location.href).hash).replace('#', '')));
|
|
232
|
-
};
|
|
233
|
-
OAuth2AuthProvider.prototype.fetchProviderRedirectURI = function () {
|
|
234
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
235
|
-
var _a, response_type, provider_id, client_id, scope, redirect_uri, state, qs, resp;
|
|
236
|
-
return __generator(this, function (_b) {
|
|
237
|
-
switch (_b.label) {
|
|
238
|
-
case 0:
|
|
239
|
-
_a = {
|
|
240
|
-
response_type: this.responseType,
|
|
241
|
-
provider_id: this.providerId,
|
|
242
|
-
client_id: this.clientId,
|
|
243
|
-
scope: this.scope,
|
|
244
|
-
redirect_uri: this.redirectUri,
|
|
245
|
-
state: btoa(JSON.stringify({
|
|
246
|
-
t: Date.now(),
|
|
247
|
-
provider_id: this.providerId,
|
|
248
|
-
client_id: this.clientId,
|
|
249
|
-
routeKey: ''
|
|
250
|
-
})),
|
|
251
|
-
}, 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;
|
|
252
|
-
qs = utils.toQueryString({
|
|
253
|
-
response_type: response_type,
|
|
254
|
-
provider_id: provider_id,
|
|
255
|
-
client_id: client_id,
|
|
256
|
-
scope: scope,
|
|
257
|
-
redirect_uri: redirect_uri,
|
|
258
|
-
state: state,
|
|
259
|
-
});
|
|
260
|
-
return [4, this.fetch(kPaths.prividerUri + "?" + qs, {
|
|
261
|
-
method: 'GET'
|
|
262
|
-
})];
|
|
263
|
-
case 1:
|
|
264
|
-
resp = _b.sent();
|
|
265
|
-
return [2, resp.json()];
|
|
266
|
-
}
|
|
267
|
-
});
|
|
268
|
-
});
|
|
269
|
-
};
|
|
270
|
-
OAuth2AuthProvider.prototype.fetchProviderToken = function (callbackInfo) {
|
|
271
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
272
|
-
var body, resp;
|
|
273
|
-
return __generator(this, function (_a) {
|
|
274
|
-
switch (_a.label) {
|
|
275
|
-
case 0:
|
|
276
|
-
body = {
|
|
277
|
-
provider_id: this.providerId,
|
|
278
|
-
client_id: this.clientId,
|
|
279
|
-
provider_redirect_uri: callbackInfo.href
|
|
280
|
-
};
|
|
281
|
-
if (callbackInfo.code) {
|
|
282
|
-
body.provider_code = callbackInfo.code;
|
|
283
|
-
}
|
|
284
|
-
else if (callbackInfo.access_token) {
|
|
285
|
-
body.provider_access_token = callbackInfo.access_token;
|
|
286
|
-
}
|
|
287
|
-
else if (callbackInfo.id_token) {
|
|
288
|
-
body.provider_id_token = callbackInfo.id_token;
|
|
289
|
-
}
|
|
290
|
-
return [4, this.fetch(kPaths.prividerToken, {
|
|
291
|
-
method: 'POST',
|
|
292
|
-
headers: {
|
|
293
|
-
'Accept': 'application/json',
|
|
294
|
-
'Content-Type': 'application/json'
|
|
295
|
-
},
|
|
296
|
-
body: JSON.stringify(body)
|
|
297
|
-
})];
|
|
298
|
-
case 1:
|
|
299
|
-
resp = _a.sent();
|
|
300
|
-
return [2, resp.json()];
|
|
301
|
-
}
|
|
302
|
-
});
|
|
303
|
-
});
|
|
304
|
-
};
|
|
305
|
-
OAuth2AuthProvider.prototype.signInWithProvider = function (callbackInfo) {
|
|
306
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
307
|
-
var token, body, resp;
|
|
308
|
-
return __generator(this, function (_a) {
|
|
309
|
-
switch (_a.label) {
|
|
310
|
-
case 0: return [4, this.fetchProviderToken(callbackInfo)];
|
|
311
|
-
case 1:
|
|
312
|
-
token = _a.sent();
|
|
313
|
-
body = {
|
|
314
|
-
client_id: this.clientId,
|
|
315
|
-
provider_token: token.provider_token,
|
|
316
|
-
sync_profile: this.syncProfile,
|
|
317
|
-
force_disable_sign_up: this.forceDisableSignUp
|
|
318
|
-
};
|
|
319
|
-
return [4, this.fetch(kPaths.signinWithProvider, {
|
|
320
|
-
method: 'POST',
|
|
321
|
-
headers: {
|
|
322
|
-
'Accept': 'application/json',
|
|
323
|
-
'Content-Type': 'application/json'
|
|
324
|
-
},
|
|
325
|
-
body: JSON.stringify(body)
|
|
326
|
-
})];
|
|
327
|
-
case 2:
|
|
328
|
-
resp = _a.sent();
|
|
329
|
-
return [2, resp.json()];
|
|
330
|
-
}
|
|
331
|
-
});
|
|
332
|
-
});
|
|
333
|
-
};
|
|
334
|
-
OAuth2AuthProvider.prototype.refreshUserInfo = function () {
|
|
335
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
336
|
-
var accessToken, authorization, resp;
|
|
337
|
-
return __generator(this, function (_a) {
|
|
338
|
-
switch (_a.label) {
|
|
339
|
-
case 0: return [4, this._request.getAccessToken()];
|
|
340
|
-
case 1:
|
|
341
|
-
accessToken = (_a.sent()).accessToken;
|
|
342
|
-
authorization = "Bearer " + accessToken;
|
|
343
|
-
return [4, this.fetch(kPaths.me, {
|
|
344
|
-
method: 'GET',
|
|
345
|
-
headers: {
|
|
346
|
-
'Accept': 'application/json',
|
|
347
|
-
'Content-Type': 'application/json',
|
|
348
|
-
'Authorization': authorization
|
|
349
|
-
}
|
|
350
|
-
})];
|
|
351
|
-
case 2:
|
|
352
|
-
resp = _a.sent();
|
|
353
|
-
return [2, resp.json()];
|
|
354
|
-
}
|
|
355
|
-
});
|
|
356
|
-
});
|
|
357
|
-
};
|
|
358
|
-
OAuth2AuthProvider.prototype.fetch = function (urlOrPath, init) {
|
|
359
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
360
|
-
var resp, seqIdFromHeader, body, seqId, body, seqId;
|
|
361
|
-
return __generator(this, function (_a) {
|
|
362
|
-
switch (_a.label) {
|
|
363
|
-
case 0: return [4, this._request.fetch(urlOrPath, init)];
|
|
364
|
-
case 1:
|
|
365
|
-
resp = _a.sent();
|
|
366
|
-
seqIdFromHeader = resp.headers.get('SeqId') || resp.headers.get('RequestId');
|
|
367
|
-
if (!(resp.status >= 400 && resp.status < 500)) return [3, 3];
|
|
368
|
-
return [4, resp.json()];
|
|
369
|
-
case 2:
|
|
370
|
-
body = _a.sent();
|
|
371
|
-
seqId = body.request_id || seqIdFromHeader;
|
|
372
|
-
throw new Error("[" + getSdkName() + "][OAuth2AuthProvider][status:" + resp.status + "][" + body.error + "(" + body.error_code + ")] " + body.error_description + " (" + seqId + ")");
|
|
373
|
-
case 3:
|
|
374
|
-
if (!(resp.status >= 500)) return [3, 5];
|
|
375
|
-
return [4, resp.json()];
|
|
376
|
-
case 4:
|
|
377
|
-
body = _a.sent();
|
|
378
|
-
seqId = body.request_id || seqIdFromHeader;
|
|
379
|
-
throw new Error("[" + getSdkName() + "][OAuth2AuthProvider][status:" + resp.status + "][" + body.error + "(" + body.error_code + ")] " + body.error_description + " (" + seqId + ")");
|
|
380
|
-
case 5: return [2, resp];
|
|
381
|
-
}
|
|
382
|
-
});
|
|
383
|
-
});
|
|
384
|
-
};
|
|
385
|
-
__decorate([
|
|
386
|
-
catchErrorsDecorator({
|
|
387
|
-
title: '跳转第三方登录平台失败',
|
|
388
|
-
messages: [
|
|
389
|
-
'请确认以下各项:',
|
|
390
|
-
' 1 - 调用 auth().oAuth2AuthProvider() 的参数是否正确',
|
|
391
|
-
"\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
|
|
392
|
-
]
|
|
393
|
-
}),
|
|
394
|
-
__metadata("design:type", Function),
|
|
395
|
-
__metadata("design:paramtypes", [Object]),
|
|
396
|
-
__metadata("design:returntype", Promise)
|
|
397
|
-
], OAuth2AuthProvider.prototype, "signInWithPopup", null);
|
|
398
|
-
return OAuth2AuthProvider;
|
|
399
|
-
}(AuthProvider));
|
|
400
|
-
export { OAuth2AuthProvider };
|
|
401
|
-
//# 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
|
-
}
|