@cloudbase/auth 1.7.3-alpha.0 → 1.8.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +13 -0
- package/dist/cjs/constants.d.ts +0 -1
- package/dist/cjs/constants.js +2 -3
- package/dist/cjs/index.d.ts +9 -13
- package/dist/cjs/index.js +120 -198
- package/dist/cjs/providers/anonymousAuthProvider.js +25 -23
- package/dist/cjs/providers/base.d.ts +1 -2
- package/dist/cjs/providers/base.js +12 -6
- package/dist/cjs/providers/customAuthProvider.js +15 -14
- package/dist/cjs/providers/emailAuthProvider.js +27 -29
- package/dist/cjs/providers/phoneAuthProvider.js +22 -24
- package/dist/cjs/providers/usernameAuthProvider.js +17 -17
- package/dist/cjs/providers/weixinAuthProvider.js +31 -30
- package/dist/esm/constants.d.ts +0 -1
- package/dist/esm/constants.js +1 -2
- package/dist/esm/index.d.ts +9 -13
- package/dist/esm/index.js +121 -199
- package/dist/esm/providers/anonymousAuthProvider.js +25 -23
- package/dist/esm/providers/base.d.ts +1 -2
- package/dist/esm/providers/base.js +12 -6
- package/dist/esm/providers/customAuthProvider.js +15 -14
- package/dist/esm/providers/emailAuthProvider.js +27 -29
- package/dist/esm/providers/phoneAuthProvider.js +22 -24
- package/dist/esm/providers/usernameAuthProvider.js +17 -17
- package/dist/esm/providers/weixinAuthProvider.js +31 -30
- package/package.json +8 -12
- package/src/constants.ts +0 -2
- package/src/index.ts +128 -245
- package/src/providers/anonymousAuthProvider.ts +15 -18
- package/src/providers/base.ts +7 -20
- package/src/providers/customAuthProvider.ts +12 -15
- package/src/providers/emailAuthProvider.ts +21 -24
- package/src/providers/phoneAuthProvider.ts +22 -23
- package/src/providers/usernameAuthProvider.ts +10 -11
- package/src/providers/weixinAuthProvider.ts +45 -46
- package/tsconfig.esm.json +2 -19
- package/tsconfig.json +2 -19
- package/.eslintrc +0 -30
- package/dist/cjs/common.d.ts +0 -8
- package/dist/cjs/common.js +0 -64
- package/dist/cjs/providers/oauth2AuthProvider.d.ts +0 -61
- package/dist/cjs/providers/oauth2AuthProvider.js +0 -404
- package/dist/esm/common.d.ts +0 -8
- package/dist/esm/common.js +0 -61
- package/dist/esm/providers/oauth2AuthProvider.d.ts +0 -61
- package/dist/esm/providers/oauth2AuthProvider.js +0 -401
- package/src/common.ts +0 -21
- package/src/providers/oauth2AuthProvider.ts +0 -585
|
@@ -2,10 +2,12 @@ var __extends = (this && this.__extends) || (function () {
|
|
|
2
2
|
var extendStatics = function (d, b) {
|
|
3
3
|
extendStatics = Object.setPrototypeOf ||
|
|
4
4
|
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
-
function (d, b) { for (var p in b) if (
|
|
5
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
6
|
return extendStatics(d, b);
|
|
7
7
|
};
|
|
8
8
|
return function (d, b) {
|
|
9
|
+
if (typeof b !== "function" && b !== null)
|
|
10
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
9
11
|
extendStatics(d, b);
|
|
10
12
|
function __() { this.constructor = d; }
|
|
11
13
|
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
@@ -35,7 +37,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
35
37
|
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
36
38
|
function step(op) {
|
|
37
39
|
if (f) throw new TypeError("Generator is already executing.");
|
|
38
|
-
while (_) try {
|
|
40
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
39
41
|
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
42
|
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
41
43
|
switch (op[0]) {
|
|
@@ -64,7 +66,7 @@ var getSdkName = constants.getSdkName, ERRORS = constants.ERRORS, COMMUNITY_SITE
|
|
|
64
66
|
var RUNTIME = adapters.RUNTIME;
|
|
65
67
|
var getQuery = utils.getQuery, getHash = utils.getHash, removeParam = utils.removeParam, printWarn = utils.printWarn;
|
|
66
68
|
var catchErrorsDecorator = helpers.catchErrorsDecorator;
|
|
67
|
-
var WeixinAuthProvider = (function (_super) {
|
|
69
|
+
export var WeixinAuthProvider = (function (_super) {
|
|
68
70
|
__extends(WeixinAuthProvider, _super);
|
|
69
71
|
function WeixinAuthProvider(config, appid, scope, state) {
|
|
70
72
|
var _this = _super.call(this, config) || this;
|
|
@@ -103,9 +105,10 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
103
105
|
WeixinAuthProvider.prototype.getLinkRedirectResult = function (options) {
|
|
104
106
|
if (options === void 0) { options = {}; }
|
|
105
107
|
return __awaiter(this, void 0, void 0, function () {
|
|
106
|
-
var
|
|
108
|
+
var withUnionId, code, appid, loginType, hybridMiniapp;
|
|
109
|
+
var _a;
|
|
107
110
|
return __generator(this, function (_b) {
|
|
108
|
-
_a = options.withUnionId,
|
|
111
|
+
withUnionId = (_a = options.withUnionId, _a === void 0 ? false : _a);
|
|
109
112
|
code = getWeixinCode();
|
|
110
113
|
if (!code) {
|
|
111
114
|
return [2, null];
|
|
@@ -126,8 +129,8 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
126
129
|
loginType: loginType,
|
|
127
130
|
code: code,
|
|
128
131
|
hybridMiniapp: hybridMiniapp,
|
|
129
|
-
withUnionId: withUnionId
|
|
130
|
-
}
|
|
132
|
+
withUnionId: withUnionId,
|
|
133
|
+
},
|
|
131
134
|
})];
|
|
132
135
|
});
|
|
133
136
|
});
|
|
@@ -141,19 +144,20 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
141
144
|
host = '//open.weixin.qq.com/connect/qrconnect';
|
|
142
145
|
}
|
|
143
146
|
try {
|
|
144
|
-
location.href = host
|
|
147
|
+
location.href = "".concat(host, "?appid=").concat(this._appid, "&redirect_uri=").concat(currUrl, "&response_type=code&scope=").concat(this._scope, "&state=").concat(this._state, "#wechat_redirect");
|
|
145
148
|
}
|
|
146
149
|
catch (e) {
|
|
147
|
-
throw new Error("["
|
|
150
|
+
throw new Error("[".concat(getSdkName(), "][").concat(ERRORS.UNKOWN_ERROR, "]").concat(e));
|
|
148
151
|
}
|
|
149
152
|
};
|
|
150
153
|
WeixinAuthProvider.prototype._signInWithCode = function (code, options) {
|
|
151
154
|
return __awaiter(this, void 0, void 0, function () {
|
|
152
|
-
var
|
|
155
|
+
var accessTokenKey, accessTokenExpireKey, refreshTokenKey, loginType, refreshTokenRes, refreshToken, loginState;
|
|
156
|
+
var _a;
|
|
153
157
|
return __generator(this, function (_b) {
|
|
154
158
|
switch (_b.label) {
|
|
155
159
|
case 0:
|
|
156
|
-
_a = this._cache.keys,
|
|
160
|
+
accessTokenKey = (_a = this._cache.keys, _a.accessTokenKey), accessTokenExpireKey = _a.accessTokenExpireKey, refreshTokenKey = _a.refreshTokenKey;
|
|
157
161
|
loginType = (function (scope) {
|
|
158
162
|
switch (scope) {
|
|
159
163
|
case 'snsapi_login':
|
|
@@ -185,7 +189,7 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
185
189
|
eventBus.fire(EVENTS.LOGIN_TYPE_CHANGED, {
|
|
186
190
|
env: this._config.env,
|
|
187
191
|
loginType: LOGINTYPE.WECHAT,
|
|
188
|
-
persistence: this._config.persistence
|
|
192
|
+
persistence: this._config.persistence,
|
|
189
193
|
});
|
|
190
194
|
return [4, this.refreshUserInfo()];
|
|
191
195
|
case 7:
|
|
@@ -193,7 +197,7 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
193
197
|
loginState = new LoginState({
|
|
194
198
|
envId: this._config.env,
|
|
195
199
|
cache: this._cache,
|
|
196
|
-
request: this._request
|
|
200
|
+
request: this._request,
|
|
197
201
|
});
|
|
198
202
|
return [4, loginState.checkLocalStateAsync()];
|
|
199
203
|
case 8:
|
|
@@ -206,9 +210,10 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
206
210
|
WeixinAuthProvider.prototype._getRefreshTokenByWXCode = function (appid, loginType, code, options) {
|
|
207
211
|
if (options === void 0) { options = {}; }
|
|
208
212
|
return __awaiter(this, void 0, void 0, function () {
|
|
209
|
-
var
|
|
213
|
+
var withUnionId, createUser, syncUserInfo, action, hybridMiniapp;
|
|
214
|
+
var _a, _b;
|
|
210
215
|
return __generator(this, function (_c) {
|
|
211
|
-
_a = options.withUnionId,
|
|
216
|
+
withUnionId = (_a = options.withUnionId, _a === void 0 ? false : _a), createUser = (_b = options.createUser, _b === void 0 ? true : _b);
|
|
212
217
|
syncUserInfo = this._scope === 'snsapi_base' ? false : options.syncUserInfo || false;
|
|
213
218
|
action = 'auth.signIn';
|
|
214
219
|
hybridMiniapp = this._runtime === RUNTIME.WX_MP ? '1' : '0';
|
|
@@ -219,21 +224,19 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
219
224
|
syncUserInfo: syncUserInfo,
|
|
220
225
|
loginCredential: code,
|
|
221
226
|
withUnionId: withUnionId,
|
|
222
|
-
createUser: createUser
|
|
227
|
+
createUser: createUser,
|
|
223
228
|
}).then(function (res) {
|
|
224
229
|
if (res.code) {
|
|
225
|
-
throw new Error("["
|
|
230
|
+
throw new Error("[".concat(getSdkName(), "][").concat(ERRORS.OPERATION_FAIL, "] failed login via wechat: ").concat(res.code));
|
|
226
231
|
}
|
|
227
232
|
if (res.refresh_token) {
|
|
228
233
|
return {
|
|
229
234
|
refreshToken: res.refresh_token,
|
|
230
235
|
accessToken: res.access_token,
|
|
231
|
-
accessTokenExpire: res.access_token_expire
|
|
236
|
+
accessTokenExpire: res.access_token_expire,
|
|
232
237
|
};
|
|
233
238
|
}
|
|
234
|
-
|
|
235
|
-
throw new Error("[" + getSdkName() + "][" + ERRORS.OPERATION_FAIL + "] action:getJwt not return refreshToken");
|
|
236
|
-
}
|
|
239
|
+
throw new Error("[".concat(getSdkName(), "][").concat(ERRORS.OPERATION_FAIL, "] action:getJwt not return refreshToken"));
|
|
237
240
|
})];
|
|
238
241
|
});
|
|
239
242
|
});
|
|
@@ -244,8 +247,8 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
244
247
|
messages: [
|
|
245
248
|
'请确认以下各项:',
|
|
246
249
|
' 1 - 调用 auth().weixinAuthProvider().signInWithRedirect() 的语法或参数是否正确',
|
|
247
|
-
"\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"
|
|
248
|
-
]
|
|
250
|
+
"\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".concat(COMMUNITY_SITE_URL),
|
|
251
|
+
],
|
|
249
252
|
}),
|
|
250
253
|
__metadata("design:type", Function),
|
|
251
254
|
__metadata("design:paramtypes", []),
|
|
@@ -259,8 +262,8 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
259
262
|
' 1 - 调用 auth().weixinAuthProvider().getRedirectResult() 的语法或参数是否正确',
|
|
260
263
|
' 2 - 当前环境是否开通了微信公众号登录授权',
|
|
261
264
|
' 3 - 微信公众号的 AppId 与 AppSecret 配置是否正确',
|
|
262
|
-
"\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"
|
|
263
|
-
]
|
|
265
|
+
"\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".concat(COMMUNITY_SITE_URL),
|
|
266
|
+
],
|
|
264
267
|
}),
|
|
265
268
|
__metadata("design:type", Function),
|
|
266
269
|
__metadata("design:paramtypes", [Object]),
|
|
@@ -274,8 +277,8 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
274
277
|
' 1 - 调用 auth().weixinAuthProvider().getLinkRedirectResult() 的语法或参数是否正确',
|
|
275
278
|
' 2 - 当前环境是否开通了微信公众号登录授权',
|
|
276
279
|
' 3 - 微信公众号的 AppId 与 AppSecret 配置是否正确',
|
|
277
|
-
"\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"
|
|
278
|
-
]
|
|
280
|
+
"\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".concat(COMMUNITY_SITE_URL),
|
|
281
|
+
],
|
|
279
282
|
}),
|
|
280
283
|
__metadata("design:type", Function),
|
|
281
284
|
__metadata("design:paramtypes", [Object]),
|
|
@@ -283,9 +286,7 @@ var WeixinAuthProvider = (function (_super) {
|
|
|
283
286
|
], WeixinAuthProvider.prototype, "getLinkRedirectResult", null);
|
|
284
287
|
return WeixinAuthProvider;
|
|
285
288
|
}(AuthProvider));
|
|
286
|
-
export { WeixinAuthProvider };
|
|
287
289
|
function getWeixinCode() {
|
|
288
290
|
return getQuery('code') || getHash('code');
|
|
289
291
|
}
|
|
290
|
-
;
|
|
291
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"weixinAuthProvider.js","sourceRoot":"","sources":["../../../src/providers/weixinAuthProvider.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, adapters,utils, helpers } from '@cloudbase/utilities/';\nimport { eventBus, EVENTS, LoginState } from '..';\nimport { LOGINTYPE } from '../constants';\n\nconst { getSdkName, ERRORS, COMMUNITY_SITE_URL } = constants;\nconst { RUNTIME } = adapters;\nconst { getQuery, getHash, removeParam, printWarn } = utils;\nconst { catchErrorsDecorator } = helpers;\n\nexport class WeixinAuthProvider extends AuthProvider {\n  private readonly _scope: string;\n  private readonly _state: string;\n  private readonly _appid: string;\n  private readonly _runtime:string;\n\n  constructor(config: ICloudbaseAuthConfig&{cache:ICloudbaseCache,request:ICloudbaseRequest,runtime:string}, appid: string, scope: string, state?: string) {\n    super(config);\n\n    this._runtime = config.runtime;\n    this._appid = appid;\n    this._scope = scope;\n    this._state = state || 'weixin';\n  }\n  \n  public async signIn(){\n    return printWarn(ERRORS.OPERATION_FAIL,'API signIn has been deprecated, please use signInWithRedirect insteed');\n  }\n  @catchErrorsDecorator({\n    title: '跳转微信公众号授权失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().weixinAuthProvider().signInWithRedirect() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`\n    ]\n  })\n  public async signInWithRedirect() {\n    return this._redirect();\n  }\n  @catchErrorsDecorator({\n    title: '微信公众号登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().weixinAuthProvider().getRedirectResult() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了微信公众号登录授权',\n      '  3 - 微信公众号的 AppId 与 AppSecret 配置是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`\n    ]\n  })\n  public async getRedirectResult(options:{ withUnionId?: boolean; syncUserInfo?: boolean }) {\n    const code = getWeixinCode();\n    if (!code) {\n      return null;\n    }\n    return this._signInWithCode(code,options);\n  }\n  @catchErrorsDecorator({\n    title: '获取微信重定向绑定结果',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().weixinAuthProvider().getLinkRedirectResult() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了微信公众号登录授权',\n      '  3 - 微信公众号的 AppId 与 AppSecret 配置是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`\n    ]\n  })\n  async getLinkRedirectResult(options: { withUnionId?: boolean } = {}) {\n    const { withUnionId = false } = options;\n    const code = getWeixinCode();\n    if (!code) {\n      return null;\n    }\n    const { _appid: appid } = this;\n    const loginType = (scope => {\n      switch (scope) {\n        case 'snsapi_login':\n          return 'WECHAT-OPEN';\n        default:\n          return 'WECHAT-PUBLIC';\n      }\n    })(this._scope);\n    const hybridMiniapp = this._runtime === RUNTIME.WX_MP ? '1' : '0';\n    return this._request.send('auth.linkWithWeixinCode', { \n      payload: { \n        appid, \n        loginType, \n        code, \n        hybridMiniapp, \n        withUnionId\n      }\n    });\n  }\n\n  private _redirect(): any {\n    let currUrl = removeParam('code', location.href);\n    currUrl = removeParam('state', currUrl);\n    currUrl = encodeURIComponent(currUrl);\n\n    let host = '//open.weixin.qq.com/connect/oauth2/authorize';\n    if (this._scope === 'snsapi_login') {\n      host = '//open.weixin.qq.com/connect/qrconnect';\n    }\n    try{\n      location.href = `${host}?appid=${this._appid}&redirect_uri=${currUrl}&response_type=code&scope=${this._scope}&state=${this._state}#wechat_redirect`;\n    }catch(e){\n      throw new Error(`[${getSdkName()}][${ERRORS.UNKOWN_ERROR}]${e}`)\n    }\n  }\n\n  private async _signInWithCode(code:string,options) {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys;\n    // 有code，用code换refresh token\n    const loginType = (scope => {\n      switch (scope) {\n        case 'snsapi_login':\n          return 'WECHAT-OPEN';\n        default:\n          return 'WECHAT-PUBLIC';\n      }\n    })(this._scope);\n\n    const refreshTokenRes = await this._getRefreshTokenByWXCode(this._appid, loginType, code,options);\n    const { refreshToken } = refreshTokenRes;\n\n    // 本地存下\n    await this._cache.setStoreAsync(refreshTokenKey, refreshToken);\n    if (refreshTokenRes.accessToken) {\n      await this._cache.setStoreAsync(accessTokenKey, refreshTokenRes.accessToken);\n    }\n    if (refreshTokenRes.accessTokenExpire) {\n      await this._cache.setStoreAsync(accessTokenExpireKey, String(refreshTokenRes.accessTokenExpire + Date.now()));\n    }\n    eventBus.fire(EVENTS.LOGIN_STATE_CHANGED);\n    // 抛出登录类型更改事件\n    eventBus.fire(EVENTS.LOGIN_TYPE_CHANGED, { \n      env: this._config.env,\n      loginType: LOGINTYPE.WECHAT, \n      persistence: this._config.persistence \n    });\n    await this.refreshUserInfo();\n    const loginState = new LoginState({\n      envId: this._config.env,\n      cache: this._cache,\n      request: this._request\n    });\n    await loginState.checkLocalStateAsync();\n    \n    return loginState;\n  }\n\n  private async _getRefreshTokenByWXCode(\n    appid: string, \n    loginType: string, \n    code: string,\n    options: any = {}\n  ): Promise<{ refreshToken: string; accessToken: string; accessTokenExpire: number }> {\n    const { withUnionId = false, createUser = true } = options;\n    // snsapi_userinfo 和 snsapi_login 才可以获取用户的微信信息\n    const syncUserInfo = this._scope === 'snsapi_base' ? false : options.syncUserInfo || false;\n\n    const action = 'auth.signIn';\n    const hybridMiniapp = this._runtime === RUNTIME.WX_MP ? '1' : '0';\n    return this._request.send(action, { \n      appid, \n      loginType, \n      hybridMiniapp,\n      syncUserInfo,\n      loginCredential: code,\n      withUnionId,\n      createUser\n    }).then(res => {\n      if (res.code) {\n        throw new Error(`[${getSdkName()}][${ERRORS.OPERATION_FAIL}] failed login via wechat: ${res.code}`);\n      }\n      if (res.refresh_token) {\n        return {\n          refreshToken: res.refresh_token,\n          accessToken: res.access_token,\n          accessTokenExpire: res.access_token_expire\n        };\n      } else {\n        throw new Error(`[${getSdkName()}][${ERRORS.OPERATION_FAIL}] action:getJwt not return refreshToken`);\n      }\n    });\n  }\n}\n\nfunction getWeixinCode () {\n  return getQuery('code') || getHash('code');\n};"]}
|
|
292
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"weixinAuthProvider.js","sourceRoot":"","sources":["../../../src/providers/weixinAuthProvider.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, adapters, utils, helpers } from '@cloudbase/utilities/';\nimport { eventBus, EVENTS, LoginState } from '..';\nimport { LOGINTYPE } from '../constants';\n\nconst { getSdkName, ERRORS, COMMUNITY_SITE_URL } = constants;\nconst { RUNTIME } = adapters;\nconst { getQuery, getHash, removeParam, printWarn } = utils;\nconst { catchErrorsDecorator } = helpers;\n\nexport class WeixinAuthProvider extends AuthProvider {\n  private readonly _scope: string;\n  private readonly _state: string;\n  private readonly _appid: string;\n  private readonly _runtime: string;\n\n  constructor(config: ICloudbaseAuthConfig&{cache: ICloudbaseCache, request: ICloudbaseRequest, runtime: string}, appid: string, scope: string, state?: string) {\n    super(config);\n\n    this._runtime = config.runtime;\n    this._appid = appid;\n    this._scope = scope;\n    this._state = state || 'weixin';\n  }\n\n  public async signIn() {\n    return printWarn(ERRORS.OPERATION_FAIL, 'API signIn has been deprecated, please use signInWithRedirect insteed');\n  }\n  @catchErrorsDecorator({\n    title: '跳转微信公众号授权失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().weixinAuthProvider().signInWithRedirect() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithRedirect() {\n    return this._redirect();\n  }\n  @catchErrorsDecorator({\n    title: '微信公众号登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().weixinAuthProvider().getRedirectResult() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了微信公众号登录授权',\n      '  3 - 微信公众号的 AppId 与 AppSecret 配置是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getRedirectResult(options: { withUnionId?: boolean; syncUserInfo?: boolean }) {\n    const code = getWeixinCode();\n    if (!code) {\n      return null;\n    }\n    return this._signInWithCode(code, options);\n  }\n  @catchErrorsDecorator({\n    title: '获取微信重定向绑定结果',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().weixinAuthProvider().getLinkRedirectResult() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了微信公众号登录授权',\n      '  3 - 微信公众号的 AppId 与 AppSecret 配置是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  async getLinkRedirectResult(options: { withUnionId?: boolean } = {}) {\n    const { withUnionId = false } = options;\n    const code = getWeixinCode();\n    if (!code) {\n      return null;\n    }\n    const { _appid: appid } = this;\n    const loginType = ((scope) => {\n      switch (scope) {\n        case 'snsapi_login':\n          return 'WECHAT-OPEN';\n        default:\n          return 'WECHAT-PUBLIC';\n      }\n    })(this._scope);\n    const hybridMiniapp = this._runtime === RUNTIME.WX_MP ? '1' : '0';\n    return this._request.send('auth.linkWithWeixinCode', {\n      payload: {\n        appid,\n        loginType,\n        code,\n        hybridMiniapp,\n        withUnionId,\n      },\n    });\n  }\n\n  private _redirect(): any {\n    let currUrl = removeParam('code', location.href);\n    currUrl = removeParam('state', currUrl);\n    currUrl = encodeURIComponent(currUrl);\n\n    let host = '//open.weixin.qq.com/connect/oauth2/authorize';\n    if (this._scope === 'snsapi_login') {\n      host = '//open.weixin.qq.com/connect/qrconnect';\n    }\n    try {\n      location.href = `${host}?appid=${this._appid}&redirect_uri=${currUrl}&response_type=code&scope=${this._scope}&state=${this._state}#wechat_redirect`;\n    } catch (e) {\n      throw new Error(`[${getSdkName()}][${ERRORS.UNKOWN_ERROR}]${e}`);\n    }\n  }\n\n  private async _signInWithCode(code: string, options) {\n    const { accessTokenKey, accessTokenExpireKey, refreshTokenKey } = this._cache.keys;\n    // 有code，用code换refresh token\n    const loginType = ((scope) => {\n      switch (scope) {\n        case 'snsapi_login':\n          return 'WECHAT-OPEN';\n        default:\n          return 'WECHAT-PUBLIC';\n      }\n    })(this._scope);\n\n    const refreshTokenRes = await this._getRefreshTokenByWXCode(this._appid, loginType, code, options);\n    const { refreshToken } = refreshTokenRes;\n\n    // 本地存下\n    await this._cache.setStoreAsync(refreshTokenKey, refreshToken);\n    if (refreshTokenRes.accessToken) {\n      await this._cache.setStoreAsync(accessTokenKey, refreshTokenRes.accessToken);\n    }\n    if (refreshTokenRes.accessTokenExpire) {\n      await this._cache.setStoreAsync(accessTokenExpireKey, String(refreshTokenRes.accessTokenExpire + Date.now()));\n    }\n    eventBus.fire(EVENTS.LOGIN_STATE_CHANGED);\n    // 抛出登录类型更改事件\n    eventBus.fire(EVENTS.LOGIN_TYPE_CHANGED, {\n      env: this._config.env,\n      loginType: LOGINTYPE.WECHAT,\n      persistence: this._config.persistence,\n    });\n    await this.refreshUserInfo();\n    const loginState = new LoginState({\n      envId: this._config.env,\n      cache: this._cache,\n      request: this._request,\n    });\n    await loginState.checkLocalStateAsync();\n\n    return loginState;\n  }\n\n  private async _getRefreshTokenByWXCode(\n    appid: string,\n    loginType: string,\n    code: string,\n    options: any = {}\n  ): Promise<{ refreshToken: string; accessToken: string; accessTokenExpire: number }> {\n    const { withUnionId = false, createUser = true } = options;\n    // snsapi_userinfo 和 snsapi_login 才可以获取用户的微信信息\n    const syncUserInfo = this._scope === 'snsapi_base' ? false : options.syncUserInfo || false;\n\n    const action = 'auth.signIn';\n    const hybridMiniapp = this._runtime === RUNTIME.WX_MP ? '1' : '0';\n    return this._request.send(action, {\n      appid,\n      loginType,\n      hybridMiniapp,\n      syncUserInfo,\n      loginCredential: code,\n      withUnionId,\n      createUser,\n    }).then((res) => {\n      if (res.code) {\n        throw new Error(`[${getSdkName()}][${ERRORS.OPERATION_FAIL}] failed login via wechat: ${res.code}`);\n      }\n      if (res.refresh_token) {\n        return {\n          refreshToken: res.refresh_token,\n          accessToken: res.access_token,\n          accessTokenExpire: res.access_token_expire,\n        };\n      }\n      throw new Error(`[${getSdkName()}][${ERRORS.OPERATION_FAIL}] action:getJwt not return refreshToken`);\n    });\n  }\n}\n\nfunction getWeixinCode() {\n  return getQuery('code') || getHash('code');\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cloudbase/auth",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.8.1",
|
|
4
4
|
"description": "cloudbase javascript sdk auth componets",
|
|
5
5
|
"main": "dist/cjs/index.js",
|
|
6
6
|
"module": "dist/esm/index.js",
|
|
@@ -28,19 +28,15 @@
|
|
|
28
28
|
"license": "ISC",
|
|
29
29
|
"dependencies": {
|
|
30
30
|
"@cloudbase/adapter-interface": "^0.4.0",
|
|
31
|
-
"@cloudbase/app": "^1.
|
|
32
|
-
"@cloudbase/types": "^1.
|
|
33
|
-
"@cloudbase/utilities": "^1.
|
|
31
|
+
"@cloudbase/app": "^1.8.1",
|
|
32
|
+
"@cloudbase/types": "^1.8.1",
|
|
33
|
+
"@cloudbase/utilities": "^1.8.1",
|
|
34
34
|
"sourcemapped-stacktrace": "^1.1.11"
|
|
35
35
|
},
|
|
36
36
|
"devDependencies": {
|
|
37
|
-
"@
|
|
38
|
-
"
|
|
39
|
-
"
|
|
40
|
-
"eslint-config-alloy": "^3.7.1",
|
|
41
|
-
"husky": "^4.2.5",
|
|
42
|
-
"lint-staged": "^10.2.0",
|
|
43
|
-
"typescript": "^3.8.3"
|
|
37
|
+
"@types/node": "^22.1.0",
|
|
38
|
+
"terser-webpack-plugin": "^3.0.2",
|
|
39
|
+
"webpack-bundle-analyzer": "^4.9.1"
|
|
44
40
|
},
|
|
45
41
|
"husky": {
|
|
46
42
|
"hooks": {
|
|
@@ -52,5 +48,5 @@
|
|
|
52
48
|
"eslint --fix"
|
|
53
49
|
]
|
|
54
50
|
},
|
|
55
|
-
"gitHead": "
|
|
51
|
+
"gitHead": "1becff3801c6dda6e3cd45127d2881aef987c7bf"
|
|
56
52
|
}
|