@steedos/accounts 2.4.2 → 2.4.4

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.
@@ -0,0 +1,157 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.geetest_validate = exports.geetest_init = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var axios = require("axios");
6
+ var GeetestConfig = require('./sdk/geetest_config');
7
+ var GeetestLib = require('./sdk/geetest_lib');
8
+ var validator = require('validator');
9
+ var geetest_status = null;
10
+ var geetest_init = function (data) { return function (req, res) { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
11
+ var gtLib, digestmod, userId, params, bypasscache, result, err_1;
12
+ return tslib_1.__generator(this, function (_a) {
13
+ switch (_a.label) {
14
+ case 0:
15
+ _a.trys.push([0, 5, , 6]);
16
+ gtLib = new GeetestLib(GeetestConfig.GEETEST_ID, GeetestConfig.GEETEST_KEY);
17
+ digestmod = "md5";
18
+ userId = "test";
19
+ params = { "digestmod": digestmod, "user_id": userId, "client_type": "web", "ip_address": "127.0.0.1" };
20
+ bypasscache = geetest_status;
21
+ result = void 0;
22
+ if (!(bypasscache === "success")) return [3, 2];
23
+ return [4, gtLib.register(digestmod, params)];
24
+ case 1:
25
+ result = _a.sent();
26
+ return [3, 4];
27
+ case 2: return [4, gtLib.localRegister()];
28
+ case 3:
29
+ result = _a.sent();
30
+ _a.label = 4;
31
+ case 4:
32
+ res.set('Content-Type', 'application/json;charset=UTF-8');
33
+ res.send(result.data);
34
+ return [3, 6];
35
+ case 5:
36
+ err_1 = _a.sent();
37
+ console.log('err', err_1);
38
+ return [3, 6];
39
+ case 6: return [2];
40
+ }
41
+ });
42
+ }); }; };
43
+ exports.geetest_init = geetest_init;
44
+ var geetest_validate = function (req, res, next) {
45
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
46
+ var gtLib, challenge, validate, seccode, bypasscache, result, params;
47
+ return tslib_1.__generator(this, function (_a) {
48
+ switch (_a.label) {
49
+ case 0:
50
+ if (!process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED) return [3, 8];
51
+ if (!(validator.toBoolean(process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED) === true)) return [3, 6];
52
+ gtLib = new GeetestLib(GeetestConfig.GEETEST_ID, GeetestConfig.GEETEST_KEY);
53
+ if (!req.body.geetest) return [3, 4];
54
+ challenge = req.body.geetest[GeetestLib.GEETEST_CHALLENGE];
55
+ validate = req.body.geetest[GeetestLib.GEETEST_VALIDATE];
56
+ seccode = req.body.geetest[GeetestLib.GEETEST_SECCODE];
57
+ bypasscache = geetest_status;
58
+ result = void 0;
59
+ params = new Array();
60
+ if (!(bypasscache === "success")) return [3, 2];
61
+ return [4, gtLib.successValidate(challenge, validate, seccode, params)];
62
+ case 1:
63
+ result = _a.sent();
64
+ return [3, 3];
65
+ case 2:
66
+ result = gtLib.failValidate(challenge, validate, seccode);
67
+ _a.label = 3;
68
+ case 3:
69
+ if (result.status === 1) {
70
+ next();
71
+ }
72
+ else {
73
+ return [2, res.json({ "result": "fail", "version": GeetestLib.VERSION, "msg": result.msg })];
74
+ }
75
+ return [3, 5];
76
+ case 4:
77
+ next();
78
+ _a.label = 5;
79
+ case 5: return [3, 7];
80
+ case 6:
81
+ next();
82
+ _a.label = 7;
83
+ case 7: return [3, 9];
84
+ case 8:
85
+ next();
86
+ _a.label = 9;
87
+ case 9: return [2];
88
+ }
89
+ });
90
+ });
91
+ };
92
+ exports.geetest_validate = geetest_validate;
93
+ function sendRequest(params) {
94
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
95
+ var request_url, bypass_res, res, resBody, e_1;
96
+ return tslib_1.__generator(this, function (_a) {
97
+ switch (_a.label) {
98
+ case 0:
99
+ request_url = GeetestConfig.BYPASS_URL;
100
+ _a.label = 1;
101
+ case 1:
102
+ _a.trys.push([1, 3, , 4]);
103
+ return [4, axios({
104
+ url: request_url,
105
+ method: "GET",
106
+ timeout: 5000,
107
+ params: params
108
+ })];
109
+ case 2:
110
+ res = _a.sent();
111
+ resBody = (res.status === 200) ? res.data : "";
112
+ bypass_res = resBody["status"];
113
+ return [3, 4];
114
+ case 3:
115
+ e_1 = _a.sent();
116
+ bypass_res = "";
117
+ return [3, 4];
118
+ case 4: return [2, bypass_res];
119
+ }
120
+ });
121
+ });
122
+ }
123
+ function sleep() {
124
+ return new Promise(function (resolve) {
125
+ setTimeout(resolve, GeetestConfig.CYCLE_TIME * 1000);
126
+ });
127
+ }
128
+ var bypass_status = 'success';
129
+ function checkBypassStatus() {
130
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
131
+ return tslib_1.__generator(this, function (_a) {
132
+ switch (_a.label) {
133
+ case 0:
134
+ if (!true) return [3, 3];
135
+ return [4, sendRequest({ "gt": GeetestConfig.GEETEST_ID })];
136
+ case 1:
137
+ bypass_status = _a.sent();
138
+ if (bypass_status === "success") {
139
+ geetest_status = bypass_status;
140
+ }
141
+ else {
142
+ bypass_status = "fail";
143
+ geetest_status = 'fail';
144
+ }
145
+ return [4, sleep()];
146
+ case 2:
147
+ _a.sent();
148
+ return [3, 0];
149
+ case 3: return [2];
150
+ }
151
+ });
152
+ });
153
+ }
154
+ if (process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED === 'true') {
155
+ checkBypassStatus();
156
+ }
157
+ //# sourceMappingURL=geetest-init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"geetest-init.js","sourceRoot":"","sources":["../../../../src/rest-express/endpoints/geetestV3/geetest-init.ts"],"names":[],"mappings":";;;;AACA,IAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;AAC/B,IAAM,aAAa,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAA;AACrD,IAAM,UAAU,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAA;AAC/C,IAAM,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;AAEvC,IAAI,cAAc,GAAG,IAAI,CAAA;AAGlB,IAAM,YAAY,GAAG,UAAC,IAAS,IAAK,OAAA,UACvC,GAAoB,EACpB,GAAqB;;;;;;gBAWX,KAAK,GAAG,IAAI,UAAU,CAAC,aAAa,CAAC,UAAU,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC;gBAC5E,SAAS,GAAG,KAAK,CAAC;gBAClB,MAAM,GAAG,MAAM,CAAC;gBAChB,MAAM,GAAG,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,CAAA;gBACvG,WAAW,GAAG,cAAc,CAAA;gBAC9B,MAAM,SAAA,CAAC;qBACP,CAAA,WAAW,KAAK,SAAS,CAAA,EAAzB,cAAyB;gBAChB,WAAM,KAAK,CAAC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC,EAAA;;gBAAhD,MAAM,GAAG,SAAuC,CAAC;;oBAExC,WAAM,KAAK,CAAC,aAAa,EAAE,EAAA;;gBAApC,MAAM,GAAG,SAA2B,CAAC;;;gBAEzC,GAAG,CAAC,GAAG,CAAC,cAAc,EAAE,gCAAgC,CAAC,CAAA;gBACzD,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;;;;gBAErB,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,KAAG,CAAC,CAAA;;oBAE3B,WAAM;;;KACT,EA9B0C,CA8B1C,CAAC;AA9BW,QAAA,YAAY,gBA8BvB;AAGK,IAAM,gBAAgB,GAAG,UAAgB,GAAG,EAAE,GAAG,EAAE,IAAI;;;;;;yBACvD,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAA3C,cAA2C;yBACtC,CAAA,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,+BAA+B,CAAC,KAAK,IAAI,CAAA,EAAzE,cAAyE;oBACnE,KAAK,GAAG,IAAI,UAAU,CAAC,aAAa,CAAC,UAAU,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC;yBAE9E,GAAG,CAAC,IAAI,CAAC,OAAO,EAAhB,cAAgB;oBACV,SAAS,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;oBAC3D,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;oBACzD,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;oBACvD,WAAW,GAAG,cAAc,CAAC;oBAC/B,MAAM,SAAA,CAAC;oBACP,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;yBACrB,CAAA,WAAW,KAAK,SAAS,CAAA,EAAzB,cAAyB;oBAChB,WAAM,KAAK,CAAC,eAAe,CAAC,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,CAAC,EAAA;;oBAA1E,MAAM,GAAG,SAAiE,CAAC;;;oBAE3E,MAAM,GAAG,KAAK,CAAC,YAAY,CAAC,SAAS,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;;;oBAG9D,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;wBACrB,IAAI,EAAE,CAAA;qBACT;yBAAM;wBACH,WAAO,GAAG,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,UAAU,CAAC,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,GAAG,EAAE,CAAC,EAAC;qBAC3F;;;oBAED,IAAI,EAAE,CAAA;;;;oBAGV,IAAI,EAAE,CAAA;;;;oBAIV,IAAI,EAAE,CAAA;;;;;;CAEb,CAAA;AAjCY,QAAA,gBAAgB,oBAiC5B;AAGD,SAAe,WAAW,CAAC,MAAM;;;;;;oBACvB,WAAW,GAAG,aAAa,CAAC,UAAU,CAAC;;;;oBAG7B,WAAM,KAAK,CAAC;4BACpB,GAAG,EAAE,WAAW;4BAChB,MAAM,EAAE,KAAK;4BACb,OAAO,EAAE,IAAI;4BACb,MAAM,EAAE,MAAM;yBACjB,CAAC,EAAA;;oBALI,GAAG,GAAG,SAKV;oBACI,OAAO,GAAG,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;oBACrD,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;;;;oBAE/B,UAAU,GAAG,EAAE,CAAC;;wBAEpB,WAAO,UAAU,EAAC;;;;CACrB;AAED,SAAS,KAAK;IACV,OAAO,IAAI,OAAO,CAAC,UAAC,OAAO;QACvB,UAAU,CAAC,OAAO,EAAE,aAAa,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IACzD,CAAC,CAAC,CAAA;AACN,CAAC;AACD,IAAI,aAAa,GAAG,SAAS,CAAC;AAC9B,SAAe,iBAAiB;;;;;yBACrB,IAAI;oBACS,WAAM,WAAW,CAAC,EAAE,IAAI,EAAE,aAAa,CAAC,UAAU,EAAE,CAAC,EAAA;;oBAArE,aAAa,GAAG,SAAqD,CAAC;oBACtE,IAAI,aAAa,KAAK,SAAS,EAAE;wBAC7B,cAAc,GAAG,aAAa,CAAA;qBACjC;yBACI;wBACD,aAAa,GAAG,MAAM,CAAA;wBACtB,cAAc,GAAG,MAAM,CAAA;qBAC1B;oBACD,WAAM,KAAK,EAAE,EAAA;;oBAAb,SAAa,CAAC;;;;;;CAErB;AACD,IAAI,OAAO,CAAC,GAAG,CAAC,+BAA+B,KAAK,MAAM,EAAE;IACxD,iBAAiB,EAAE,CAAA;CACtB"}
@@ -0,0 +1,11 @@
1
+ var GeetestConfig = Object.freeze({
2
+ GEETEST_ID: process.env.STEEDOS_CAPTCHA_GEETEST_ID,
3
+ GEETEST_KEY: process.env.STEEDOS_CAPTCHA_GEETEST_KEY,
4
+ REDIS_HOST: "127.0.0.1",
5
+ REDIS_PORT: "6379",
6
+ BYPASS_URL: "http://bypass.geetest.com/v1/bypass_status.php",
7
+ CYCLE_TIME: 10,
8
+ GEETEST_BYPASS_STATUS_KEY: "gt_server_bypass_status"
9
+ });
10
+ module.exports = GeetestConfig;
11
+ //# sourceMappingURL=geetest_config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"geetest_config.js","sourceRoot":"","sources":["../../../../../src/rest-express/endpoints/geetestV3/sdk/geetest_config.js"],"names":[],"mappings":"AAAA,IAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC;IAChC,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,0BAA0B;IAClD,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,2BAA2B;IACpD,UAAU,EAAE,WAAW;IACvB,UAAU,EAAE,MAAM;IAClB,UAAU,EAAE,gDAAgD;IAC5D,UAAU,EAAE,EAAE;IACd,yBAAyB,EAAE,yBAAyB;CACvD,CAAC,CAAA;AAEF,MAAM,CAAC,OAAO,GAAG,aAAa,CAAA"}
@@ -0,0 +1,211 @@
1
+ var tslib_1 = require("tslib");
2
+ var stringRandom = require('string-random');
3
+ var crypto = require('crypto');
4
+ var axios = require('axios');
5
+ var qs = require('qs');
6
+ var GeetestLibResult = require("./geetest_lib_result");
7
+ var GeetestLib = (function () {
8
+ function GeetestLib(geetest_id, geetest_key) {
9
+ this.geetest_id = geetest_id;
10
+ this.geetest_key = geetest_key;
11
+ this.libResult = new GeetestLibResult();
12
+ }
13
+ GeetestLib.prototype.gtlog = function (message) {
14
+ if (GeetestLib.IS_DEBUG) {
15
+ console.log("gtlog: " + message);
16
+ }
17
+ };
18
+ GeetestLib.prototype.register = function (digestmod, params) {
19
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
20
+ var origin_challenge;
21
+ return tslib_1.__generator(this, function (_a) {
22
+ switch (_a.label) {
23
+ case 0: return [4, this.requestRegister(params)];
24
+ case 1:
25
+ origin_challenge = _a.sent();
26
+ this.buildRegisterResult(origin_challenge, digestmod);
27
+ return [2, this.libResult];
28
+ }
29
+ });
30
+ });
31
+ };
32
+ GeetestLib.prototype.requestRegister = function (params) {
33
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
34
+ var register_url, origin_challenge, res, resBody, e_1;
35
+ return tslib_1.__generator(this, function (_a) {
36
+ switch (_a.label) {
37
+ case 0:
38
+ params = Object.assign(params, {
39
+ "gt": this.geetest_id,
40
+ "json_format": GeetestLib.JSON_FORMAT,
41
+ "sdk": GeetestLib.VERSION
42
+ });
43
+ register_url = GeetestLib.API_URL + GeetestLib.REGISTER_URL;
44
+ _a.label = 1;
45
+ case 1:
46
+ _a.trys.push([1, 3, , 4]);
47
+ return [4, axios({
48
+ url: register_url,
49
+ method: "GET",
50
+ timeout: GeetestLib.HTTP_TIMEOUT_DEFAULT,
51
+ params: params
52
+ })];
53
+ case 2:
54
+ res = _a.sent();
55
+ resBody = (res.status === 200) ? res.data : "";
56
+ origin_challenge = resBody["challenge"];
57
+ return [3, 4];
58
+ case 3:
59
+ e_1 = _a.sent();
60
+ origin_challenge = "";
61
+ return [3, 4];
62
+ case 4: return [2, origin_challenge];
63
+ }
64
+ });
65
+ });
66
+ };
67
+ GeetestLib.prototype.localRegister = function () {
68
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
69
+ return tslib_1.__generator(this, function (_a) {
70
+ this.buildRegisterResult("", "");
71
+ return [2, this.libResult];
72
+ });
73
+ });
74
+ };
75
+ GeetestLib.prototype.buildRegisterResult = function (origin_challenge, digestmod) {
76
+ if (!origin_challenge || origin_challenge === "0") {
77
+ var challenge = stringRandom(32).toLowerCase();
78
+ var data = {
79
+ "success": 0,
80
+ "gt": this.geetest_id,
81
+ "challenge": challenge,
82
+ "new_captcha": GeetestLib.NEW_CAPTCHA
83
+ };
84
+ this.libResult.setAll(0, JSON.stringify(data), "获取当前缓存中bypass状态为fail,本地生成challenge,后续流程走宕机模式");
85
+ }
86
+ else {
87
+ var challenge = void 0;
88
+ if (digestmod === "md5") {
89
+ challenge = this.md5_encode(origin_challenge + this.geetest_key);
90
+ }
91
+ else if (digestmod === "sha256") {
92
+ challenge = this.sha256_encode(origin_challenge + this.geetest_key);
93
+ }
94
+ else if (digestmod === "hmac-sha256") {
95
+ challenge = this.hmac_sha256_encode(origin_challenge, this.geetest_key);
96
+ }
97
+ else {
98
+ challenge = this.md5_encode(origin_challenge + this.geetest_key);
99
+ }
100
+ var data = {
101
+ "success": 1,
102
+ "gt": this.geetest_id,
103
+ "challenge": challenge,
104
+ "new_captcha": GeetestLib.NEW_CAPTCHA
105
+ };
106
+ this.libResult.setAll(1, JSON.stringify(data), "");
107
+ }
108
+ };
109
+ GeetestLib.prototype.successValidate = function (challenge, validate, seccode, params) {
110
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
111
+ var response_seccode;
112
+ return tslib_1.__generator(this, function (_a) {
113
+ switch (_a.label) {
114
+ case 0:
115
+ if (!!this.checkParam(challenge, validate, seccode)) return [3, 1];
116
+ this.libResult.setAll(0, "", "正常模式,本地校验,参数challenge、validate、seccode不可为空");
117
+ return [3, 3];
118
+ case 1: return [4, this.requestValidate(challenge, validate, seccode, params)];
119
+ case 2:
120
+ response_seccode = _a.sent();
121
+ if (!response_seccode) {
122
+ this.libResult.setAll(0, "", "请求极验validate接口失败");
123
+ }
124
+ else if (response_seccode === "false") {
125
+ this.libResult.setAll(0, "", "极验二次验证不通过");
126
+ }
127
+ else {
128
+ this.libResult.setAll(1, "", "");
129
+ }
130
+ _a.label = 3;
131
+ case 3: return [2, this.libResult];
132
+ }
133
+ });
134
+ });
135
+ };
136
+ GeetestLib.prototype.failValidate = function (challenge, validate, seccode) {
137
+ if (!this.checkParam(challenge, validate, seccode)) {
138
+ this.libResult.setAll(0, "", "宕机模式,本地校验,参数challenge、validate、seccode不可为空.");
139
+ }
140
+ else {
141
+ this.libResult.setAll(1, "", "");
142
+ }
143
+ return this.libResult;
144
+ };
145
+ GeetestLib.prototype.requestValidate = function (challenge, validate, seccode, params) {
146
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
147
+ var validate_url, response_seccode, res, resBody, e_2;
148
+ return tslib_1.__generator(this, function (_a) {
149
+ switch (_a.label) {
150
+ case 0:
151
+ params = Object.assign(params, {
152
+ "seccode": seccode,
153
+ "json_format": GeetestLib.JSON_FORMAT,
154
+ "challenge": challenge,
155
+ "sdk": GeetestLib.VERSION,
156
+ "captchaid": this.geetest_id
157
+ });
158
+ validate_url = GeetestLib.API_URL + GeetestLib.VALIDATE_URL;
159
+ _a.label = 1;
160
+ case 1:
161
+ _a.trys.push([1, 3, , 4]);
162
+ return [4, axios({
163
+ url: validate_url,
164
+ method: "POST",
165
+ timeout: GeetestLib.HTTP_TIMEOUT_DEFAULT,
166
+ data: qs.stringify(params),
167
+ headers: { "Content-Type": "application/x-www-form-urlencoded" }
168
+ }).catch(function (err) {
169
+ })];
170
+ case 2:
171
+ res = _a.sent();
172
+ resBody = (res.status === 200) ? res.data : "";
173
+ response_seccode = resBody["seccode"];
174
+ return [3, 4];
175
+ case 3:
176
+ e_2 = _a.sent();
177
+ response_seccode = "";
178
+ return [3, 4];
179
+ case 4: return [2, response_seccode];
180
+ }
181
+ });
182
+ });
183
+ };
184
+ GeetestLib.prototype.checkParam = function (challenge, validate, seccode) {
185
+ return !(challenge == undefined || challenge.trim() === "" || validate == undefined || validate.trim() === "" || seccode == undefined || seccode.trim() === "");
186
+ };
187
+ GeetestLib.prototype.md5_encode = function (value) {
188
+ return crypto.createHash("md5").update(value).digest("hex");
189
+ };
190
+ GeetestLib.prototype.sha256_encode = function (value) {
191
+ return crypto.createHash("sha256").update(value).digest("hex");
192
+ };
193
+ GeetestLib.prototype.hmac_sha256_encode = function (value, key) {
194
+ return crypto.createHmac("sha256", key).update(value).digest("hex");
195
+ };
196
+ GeetestLib.IS_DEBUG = true;
197
+ GeetestLib.API_URL = "http://api.geetest.com";
198
+ GeetestLib.REGISTER_URL = "/register.php";
199
+ GeetestLib.VALIDATE_URL = "/validate.php";
200
+ GeetestLib.JSON_FORMAT = "1";
201
+ GeetestLib.NEW_CAPTCHA = true;
202
+ GeetestLib.HTTP_TIMEOUT_DEFAULT = 5000;
203
+ GeetestLib.VERSION = "node-express:3.1.1";
204
+ GeetestLib.GEETEST_CHALLENGE = "geetest_challenge";
205
+ GeetestLib.GEETEST_VALIDATE = "geetest_validate";
206
+ GeetestLib.GEETEST_SECCODE = "geetest_seccode";
207
+ GeetestLib.GEETEST_SERVER_STATUS_SESSION_KEY = "gt_server_status";
208
+ return GeetestLib;
209
+ }());
210
+ module.exports = GeetestLib;
211
+ //# sourceMappingURL=geetest_lib.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"geetest_lib.js","sourceRoot":"","sources":["../../../../../src/rest-express/endpoints/geetestV3/sdk/geetest_lib.js"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ var GeetestLibResult = (function () {
2
+ function GeetestLibResult() {
3
+ this.status = 0;
4
+ this.data = "";
5
+ this.msg = "";
6
+ }
7
+ GeetestLibResult.prototype.setAll = function (status, data, msg) {
8
+ this.status = status;
9
+ this.data = data;
10
+ this.msg = msg;
11
+ };
12
+ GeetestLibResult.prototype.toString = function () {
13
+ return "GeetestLibResult{status=".concat(this.status, ", data=").concat(this.data, ", msg=").concat(this.msg, "}");
14
+ };
15
+ return GeetestLibResult;
16
+ }());
17
+ module.exports = GeetestLibResult;
18
+ //# sourceMappingURL=geetest_lib_result.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"geetest_lib_result.js","sourceRoot":"","sources":["../../../../../src/rest-express/endpoints/geetestV3/sdk/geetest_lib_result.js"],"names":[],"mappings":"AACA;IACI;QACI,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAChB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;IAClB,CAAC;IAED,iCAAM,GAAN,UAAO,MAAM,EAAE,IAAI,EAAE,GAAG;QACpB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACnB,CAAC;IAED,mCAAQ,GAAR;QACI,OAAO,kCAA2B,IAAI,CAAC,MAAM,oBAAU,IAAI,CAAC,IAAI,mBAAS,IAAI,CAAC,GAAG,MAAG,CAAC;IACzF,CAAC;IACL,uBAAC;AAAD,CAAC,AAhBD,IAgBC;AAED,MAAM,CAAC,OAAO,GAAG,gBAAgB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"verify-email.js","sourceRoot":"","sources":["../../../../src/rest-express/endpoints/password/verify-email.ts"],"names":[],"mappings":";;;;AAEA,qDAAmD;AAE5C,IAAM,WAAW,GAAG,UAAC,cAA8B,IAAK,OAAA,UAC7D,GAAoB,EACpB,GAAqB;;;;;;gBAGX,KAAK,GAAK,GAAG,CAAC,IAAI,MAAb,CAAc;gBACrB,QAAQ,GAAQ,cAAc,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAC5D,WAAM,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,EAAA;;gBAAjC,SAAiC,CAAC;gBAClC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;;;gBAEf,IAAA,sBAAS,EAAC,GAAG,EAAE,KAAG,CAAC,CAAC;;;;;KAEvB,EAZ8D,CAY9D,CAAC;AAZW,QAAA,WAAW,eAYtB;AAEK,IAAM,qBAAqB,GAAG,UAAC,cAA8B,IAAK,OAAA,UACvE,GAAoB,EACpB,GAAqB;;;;;;gBAGX,KAAK,GAAK,GAAG,CAAC,IAAI,MAAb,CAAc;gBACrB,QAAQ,GAAQ,cAAc,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAC5D,WAAM,QAAQ,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAA;;gBAA3C,SAA2C,CAAC;gBAC5C,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;;;gBAEf,IAAA,sBAAS,EAAC,GAAG,EAAE,KAAG,CAAC,CAAC;;;;;KAEvB,EAZwE,CAYxE,CAAC;AAZW,QAAA,qBAAqB,yBAYhC;AAEK,IAAM,oBAAoB,GAAG,UAAC,cAA8B,IAAK,OAAA,UACtE,GAAoB,EACpB,GAAqB;;;;;;gBAGX,IAAI,GAAK,GAAG,CAAC,IAAI,KAAb,CAAc;gBACpB,QAAQ,GAAQ,cAAc,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAC7C,WAAM,QAAQ,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAA;;gBAAlD,MAAM,GAAG,SAAyC;gBACxD,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;;;gBAEjB,IAAA,sBAAS,EAAC,GAAG,EAAE,KAAG,CAAC,CAAC;;;;;KAEvB,EAZuE,CAYvE,CAAC;AAZW,QAAA,oBAAoB,wBAY/B"}
1
+ {"version":3,"file":"verify-email.js","sourceRoot":"","sources":["../../../../src/rest-express/endpoints/password/verify-email.ts"],"names":[],"mappings":";;;;AAEA,qDAAmD;AAE5C,IAAM,WAAW,GAAG,UAAC,cAA8B,IAAK,OAAA,UAC7D,GAAoB,EACpB,GAAqB;;;;;;gBAGX,KAAK,GAAK,GAAG,CAAC,IAAI,MAAb,CAAc;gBACrB,QAAQ,GAAQ,cAAc,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAC5D,WAAM,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,EAAA;;gBAAjC,SAAiC,CAAC;gBAClC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;;;gBAEf,IAAA,sBAAS,EAAC,GAAG,EAAE,KAAG,CAAC,CAAC;;;;;KAEvB,EAZ8D,CAY9D,CAAC;AAZW,QAAA,WAAW,eAYtB;AAEK,IAAM,qBAAqB,GAAG,UAAC,cAA8B,IAAK,OAAA,UACvE,GAAoB,EACpB,GAAqB;;;;;;gBAGX,KAAK,GAAK,GAAG,CAAC,IAAI,MAAb,CAAc;gBACrB,QAAQ,GAAQ,cAAc,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAC5D,WAAM,QAAQ,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAA;;gBAA3C,SAA2C,CAAC;gBAC5C,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;;;gBAEf,IAAA,sBAAS,EAAC,GAAG,EAAE,KAAG,CAAC,CAAC;;;;;KAEvB,EAZwE,CAYxE,CAAC;AAZW,QAAA,qBAAqB,yBAYhC;AAEK,IAAM,oBAAoB,GAAG,UAAC,cAA8B,IAAK,OAAA,UACtE,GAAoB,EACpB,GAAqB;;;;;;gBAGX,IAAI,GAAI,GAAG,CAAC,IAAI,KAAZ,CAAa;gBACnB,QAAQ,GAAQ,cAAc,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAC7C,WAAM,QAAQ,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAA;;gBAAlD,MAAM,GAAG,SAAyC;gBACxD,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;;;gBAEjB,IAAA,sBAAS,EAAC,GAAG,EAAE,KAAG,CAAC,CAAC;;;;;KAEvB,EAZuE,CAYvE,CAAC;AAZW,QAAA,oBAAoB,wBAY/B"}
@@ -27,7 +27,8 @@ var getSettings = function (accountsServer) { return function (req, res) { retur
27
27
  enable_email_code_login: false,
28
28
  enable_bind_mobile: false,
29
29
  enable_bind_email: false,
30
- enable_saas: validator.toBoolean(process.env.STEEDOS_TENANT_ENABLE_SAAS || 'false', true)
30
+ enable_saas: validator.toBoolean(process.env.STEEDOS_TENANT_ENABLE_SAAS || 'false', true),
31
+ enable_open_geetest: validator.toBoolean(process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED || 'false')
31
32
  };
32
33
  if (config.tenant) {
33
34
  _.assignIn(tenant, config.tenant);
@@ -76,7 +77,8 @@ var getSettings = function (accountsServer) { return function (req, res) { retur
76
77
  root_url: process.env.ROOT_URL,
77
78
  already_mail_service: already_mail_service,
78
79
  already_sms_service: already_sms_service,
79
- serverInitInfo: serverInitInfo
80
+ serverInitInfo: serverInitInfo,
81
+ redirect_url_whitelist: process.env.REDIRECT_URL_WHITELIST
80
82
  });
81
83
  return [2];
82
84
  }
@@ -1 +1 @@
1
- {"version":3,"file":"settings.js","sourceRoot":"","sources":["../../../../src/rest-express/endpoints/steedos/settings.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"settings.js","sourceRoot":"","sources":["../../../../src/rest-express/endpoints/steedos/settings.ts"],"names":[],"mappings":"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"}
@@ -22,6 +22,7 @@ var put_user_name_1 = require("./endpoints/put-user-name");
22
22
  var login_1 = require("./endpoints/login");
23
23
  var spaces_1 = require("./endpoints/spaces");
24
24
  var verify_1 = require("./endpoints/password/verify");
25
+ var geetest_init_1 = require("./endpoints/geetestV3/geetest-init");
25
26
  var defaultOptions = {
26
27
  path: '/accounts',
27
28
  };
@@ -53,10 +54,11 @@ var accountsExpress = function (accountsServer, options) {
53
54
  router.post("".concat(path, "/password/verifyEmail"), (0, verify_email_1.verifyEmail)(accountsServer));
54
55
  router.post("".concat(path, "/password/resetPassword"), (0, reset_1.resetPassword)(accountsServer));
55
56
  router.post("".concat(path, "/password/sendVerificationEmail"), (0, verify_email_1.sendVerificationEmail)(accountsServer));
56
- router.post("".concat(path, "/password/sendVerificationCode"), (0, verify_email_1.sendVerificationCode)(accountsServer));
57
+ router.post("".concat(path, "/password/sendVerificationCode"), geetest_init_1.geetest_validate, (0, verify_email_1.sendVerificationCode)(accountsServer));
57
58
  router.post("".concat(path, "/password/sendResetPasswordEmail"), (0, reset_1.sendResetPasswordEmail)(accountsServer));
58
59
  router.post("".concat(path, "/password/verify/email"), (0, user_loader_1.userLoader)(accountsServer), (0, verify_1.verify_email)(accountsServer));
59
60
  router.post("".concat(path, "/password/verify/mobile"), (0, user_loader_1.userLoader)(accountsServer), (0, verify_1.verify_mobile)(accountsServer));
61
+ router.post("".concat(path, "/geetest/geetest-init"), (0, geetest_init_1.geetest_init)(accountsServer));
60
62
  router.post("".concat(path, "/password/changePassword"), (0, user_loader_1.userLoader)(accountsServer), (0, change_password_1.changePassword)(accountsServer));
61
63
  }
62
64
  if (services.oauth) {
@@ -1 +1 @@
1
- {"version":3,"file":"express-middleware.js","sourceRoot":"","sources":["../../src/rest-express/express-middleware.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"express-middleware.js","sourceRoot":"","sources":["../../src/rest-express/express-middleware.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@steedos/accounts",
3
3
  "private": false,
4
- "version": "2.4.2",
4
+ "version": "2.4.4",
5
5
  "main": "lib/index.js",
6
6
  "files": [
7
7
  "/package.json",
@@ -36,6 +36,7 @@
36
36
  "cookie-parser": "1.4.3",
37
37
  "cookies": "^0.8.0",
38
38
  "cors": "2.8.5",
39
+ "crypto": "^1.0.1",
39
40
  "csurf": "^1.11.0",
40
41
  "emittery": "0.11.0",
41
42
  "express": "4.17.1",
@@ -49,25 +50,26 @@
49
50
  "nodemailer": "^6.3.0",
50
51
  "pug": "^3.0.2",
51
52
  "request-ip": "^2.2.0",
53
+ "string-random": "^0.1.3",
52
54
  "tslib": "^2.4.0",
53
55
  "url-join": "^4.0.1",
54
56
  "validator": "^13.6.0"
55
57
  },
56
58
  "devDependencies": {
57
- "@steedos/auth": "2.4.2",
58
- "@steedos/meteor-bundle-runner": "2.4.2",
59
- "@steedos/objectql": "2.4.2",
59
+ "@steedos/auth": "2.4.4",
60
+ "@steedos/meteor-bundle-runner": "2.4.4",
61
+ "@steedos/objectql": "2.4.4",
60
62
  "@types/dotenv-flow": "^3.0.0",
61
63
  "@types/node": "12.6.8",
62
64
  "cross-env": "^7.0.3",
63
65
  "dotenv": "^8.2.0",
64
66
  "dotenv-flow": "^3.1.0",
65
67
  "nodemon": "^2.0.19",
66
- "steedos-server": "2.4.2",
68
+ "steedos-server": "2.4.4",
67
69
  "typescript": "4.6.3"
68
70
  },
69
71
  "publishConfig": {
70
72
  "access": "public"
71
73
  },
72
- "gitHead": "0e880759058022827b737df329c254aff2bc94dc"
74
+ "gitHead": "04caa0eb2226278f96c01825dd2828170c1f9789"
73
75
  }
@@ -0,0 +1,125 @@
1
+ import * as express from 'express';
2
+ const axios = require("axios");
3
+ const GeetestConfig = require('./sdk/geetest_config')
4
+ const GeetestLib = require('./sdk/geetest_lib')
5
+ const validator = require('validator');
6
+
7
+ let geetest_status = null
8
+
9
+ //初始化
10
+ export const geetest_init = (data: any) => async (
11
+ req: express.Request,
12
+ res: express.Response
13
+ ) => {
14
+ try {
15
+ /*
16
+ 必传参数
17
+ digestmod 此版本sdk可支持md5、sha256、hmac-sha256,md5之外的算法需特殊配置的账号,联系极验客服
18
+ 自定义参数,可选择添加
19
+ user_id 客户端用户的唯一标识,确定用户的唯一性;作用于提供进阶数据分析服务,可在register和validate接口传入,不传入也不影响验证服务的使用;若担心用户信息风险,可作预处理(如哈希处理)再提供到极验
20
+ client_type 客户端类型,web:电脑上的浏览器;h5:手机上的浏览器,包括移动应用内完全内置的web_view;native:通过原生sdk植入app应用的方式;unknown:未知
21
+ ip_address 客户端请求sdk服务器的ip地址
22
+ */
23
+ const gtLib = new GeetestLib(GeetestConfig.GEETEST_ID, GeetestConfig.GEETEST_KEY);
24
+ const digestmod = "md5";
25
+ const userId = "test";
26
+ const params = { "digestmod": digestmod, "user_id": userId, "client_type": "web", "ip_address": "127.0.0.1" }
27
+ const bypasscache = geetest_status
28
+ let result;
29
+ if (bypasscache === "success") {
30
+ result = await gtLib.register(digestmod, params);
31
+ } else {
32
+ result = await gtLib.localRegister();
33
+ }
34
+ res.set('Content-Type', 'application/json;charset=UTF-8')
35
+ res.send(result.data)
36
+ } catch (err) {
37
+ console.log('err', err)
38
+ }
39
+ return
40
+ };
41
+
42
+ // 二次验证接口,POST请求
43
+ export const geetest_validate = async function (req, res, next) {
44
+ if(process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED){
45
+ if (validator.toBoolean(process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED) === true) {
46
+ const gtLib = new GeetestLib(GeetestConfig.GEETEST_ID, GeetestConfig.GEETEST_KEY);
47
+
48
+ if (req.body.geetest) {
49
+ const challenge = req.body.geetest[GeetestLib.GEETEST_CHALLENGE];
50
+ const validate = req.body.geetest[GeetestLib.GEETEST_VALIDATE];
51
+ const seccode = req.body.geetest[GeetestLib.GEETEST_SECCODE];
52
+ const bypasscache = geetest_status;
53
+ let result;
54
+ var params = new Array();
55
+ if (bypasscache === "success") {
56
+ result = await gtLib.successValidate(challenge, validate, seccode, params);
57
+ } else {
58
+ result = gtLib.failValidate(challenge, validate, seccode);
59
+ }
60
+ // 注意,不要更改返回的结构和值类型
61
+ if (result.status === 1) {
62
+ next()
63
+ } else {
64
+ return res.json({ "result": "fail", "version": GeetestLib.VERSION, "msg": result.msg });
65
+ }
66
+ } else {
67
+ next()
68
+ }
69
+ } else {
70
+ next()
71
+ }
72
+
73
+ }else{
74
+ next()
75
+ }
76
+ }
77
+
78
+
79
+ async function sendRequest(params) {
80
+ const request_url = GeetestConfig.BYPASS_URL;
81
+ let bypass_res;
82
+ try {
83
+ const res = await axios({
84
+ url: request_url,
85
+ method: "GET",
86
+ timeout: 5000,
87
+ params: params
88
+ });
89
+ const resBody = (res.status === 200) ? res.data : "";
90
+ bypass_res = resBody["status"];
91
+ } catch (e) {
92
+ bypass_res = "";
93
+ }
94
+ return bypass_res;
95
+ }
96
+
97
+ function sleep() {
98
+ return new Promise((resolve) => {
99
+ setTimeout(resolve, GeetestConfig.CYCLE_TIME * 1000);
100
+ })
101
+ }
102
+ let bypass_status = 'success';
103
+ async function checkBypassStatus() {
104
+ while (true) {
105
+ bypass_status = await sendRequest({ "gt": GeetestConfig.GEETEST_ID });
106
+ if (bypass_status === "success") {
107
+ geetest_status = bypass_status
108
+ }
109
+ else {
110
+ bypass_status = "fail"
111
+ geetest_status = 'fail'
112
+ }
113
+ await sleep();
114
+ }
115
+ }
116
+ if (process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED === 'true') {
117
+ checkBypassStatus()
118
+ }
119
+
120
+
121
+
122
+
123
+
124
+
125
+
@@ -0,0 +1,11 @@
1
+ const GeetestConfig = Object.freeze({
2
+ GEETEST_ID: process.env.STEEDOS_CAPTCHA_GEETEST_ID,
3
+ GEETEST_KEY: process.env.STEEDOS_CAPTCHA_GEETEST_KEY,
4
+ REDIS_HOST: "127.0.0.1",
5
+ REDIS_PORT: "6379",
6
+ BYPASS_URL: "http://bypass.geetest.com/v1/bypass_status.php",
7
+ CYCLE_TIME: 10,
8
+ GEETEST_BYPASS_STATUS_KEY: "gt_server_bypass_status"
9
+ })
10
+
11
+ module.exports = GeetestConfig
@@ -0,0 +1,217 @@
1
+ const stringRandom = require('string-random');
2
+ const crypto = require('crypto');
3
+ const axios = require('axios');
4
+ const qs = require('qs');
5
+
6
+ const GeetestLibResult = require("./geetest_lib_result");
7
+
8
+ class GeetestLib {
9
+ static IS_DEBUG = true; // 调试开关,是否输出调试日志
10
+ static API_URL = "http://api.geetest.com";
11
+ static REGISTER_URL = "/register.php";
12
+ static VALIDATE_URL = "/validate.php";
13
+ static JSON_FORMAT = "1";
14
+ static NEW_CAPTCHA = true;
15
+ static HTTP_TIMEOUT_DEFAULT = 5000; // 单位:毫秒
16
+ static VERSION = "node-express:3.1.1";
17
+ static GEETEST_CHALLENGE = "geetest_challenge"; // 极验二次验证表单传参字段 chllenge
18
+ static GEETEST_VALIDATE = "geetest_validate"; // 极验二次验证表单传参字段 validate
19
+ static GEETEST_SECCODE = "geetest_seccode"; // 极验二次验证表单传参字段 seccode
20
+ static GEETEST_SERVER_STATUS_SESSION_KEY = "gt_server_status"; // 极验验证API服务状态Session Key
21
+
22
+ constructor(geetest_id, geetest_key) {
23
+ this.geetest_id = geetest_id;
24
+ this.geetest_key = geetest_key;
25
+ this.libResult = new GeetestLibResult();
26
+ }
27
+
28
+ gtlog(message) {
29
+ if (GeetestLib.IS_DEBUG) {
30
+ console.log("gtlog: " + message);
31
+ }
32
+ }
33
+
34
+ /**
35
+ * 验证初始化
36
+ */
37
+ async register(digestmod, params) {
38
+ // this.gtlog(`register(): 开始验证初始化, digestmod=${digestmod}.`);
39
+ const origin_challenge = await this.requestRegister(params);
40
+ this.buildRegisterResult(origin_challenge, digestmod)
41
+ // this.gtlog(`register(): 验证初始化, lib包返回信息=${this.libResult}.`);
42
+ return this.libResult
43
+ }
44
+
45
+ /**
46
+ * 向极验发送验证初始化的请求,GET方式
47
+ */
48
+ async requestRegister(params) {
49
+ params = Object.assign(params, {
50
+ "gt": this.geetest_id,
51
+ "json_format": GeetestLib.JSON_FORMAT,
52
+ "sdk": GeetestLib.VERSION
53
+ });
54
+ const register_url = GeetestLib.API_URL + GeetestLib.REGISTER_URL;
55
+ // console.log('register_url是', register_url)
56
+ // this.gtlog(`requestRegister(): 验证初始化, 向极验发送请求, url=${register_url}, params=${JSON.stringify(params)}.`);
57
+ let origin_challenge;
58
+ try {
59
+ const res = await axios({
60
+ url: register_url,
61
+ method: "GET",
62
+ timeout: GeetestLib.HTTP_TIMEOUT_DEFAULT,
63
+ params: params
64
+ })
65
+ // console.log('返回值是', res)
66
+ const resBody = (res.status === 200) ? res.data : "";
67
+ // this.gtlog(`requestRegister(): 验证初始化, 与极验网络交互正常, 返回码=${res.status}, 返回body=${JSON.stringify(resBody)}.`);
68
+ origin_challenge = resBody["challenge"];
69
+ } catch (e) {
70
+ // this.gtlog("requestRegister(): 验证初始化, 请求异常,后续流程走宕机模式!, " + e.message);
71
+ origin_challenge = "";
72
+ }
73
+ return origin_challenge;
74
+ }
75
+ async localRegister() {
76
+ // this.gtlog("获取当前缓存中bypass状态为fail,后续流程走宕机模式 ");
77
+ this.buildRegisterResult("", "")
78
+ // this.gtlog(`register(): 验证初始化, lib包返回信息=${this.libResult}.`);
79
+ return this.libResult
80
+ }
81
+ /**
82
+ * 构建验证初始化返回数据
83
+ */
84
+ buildRegisterResult(origin_challenge, digestmod) {
85
+ // origin_challenge为空或者值为0代表失败
86
+ if (!origin_challenge || origin_challenge === "0") {
87
+ // 本地随机生成32位字符串
88
+ const challenge = stringRandom(32).toLowerCase();
89
+ const data = {
90
+ "success": 0,
91
+ "gt": this.geetest_id,
92
+ "challenge": challenge,
93
+ "new_captcha": GeetestLib.NEW_CAPTCHA
94
+ };
95
+ this.libResult.setAll(0, JSON.stringify(data), "获取当前缓存中bypass状态为fail,本地生成challenge,后续流程走宕机模式")
96
+ } else {
97
+ let challenge;
98
+ if (digestmod === "md5") {
99
+ challenge = this.md5_encode(origin_challenge + this.geetest_key);
100
+ } else if (digestmod === "sha256") {
101
+ challenge = this.sha256_encode(origin_challenge + this.geetest_key);
102
+ } else if (digestmod === "hmac-sha256") {
103
+ challenge = this.hmac_sha256_encode(origin_challenge, this.geetest_key);
104
+ } else {
105
+ challenge = this.md5_encode(origin_challenge + this.geetest_key);
106
+ }
107
+ const data = {
108
+ "success": 1,
109
+ "gt": this.geetest_id,
110
+ "challenge": challenge,
111
+ "new_captcha": GeetestLib.NEW_CAPTCHA
112
+ };
113
+ this.libResult.setAll(1, JSON.stringify(data), "");
114
+ }
115
+ }
116
+
117
+ /**
118
+ * 正常流程下(即验证初始化成功),二次验证
119
+ */
120
+ async successValidate(challenge, validate, seccode, params) {
121
+ // this.gtlog(`successValidate(): 开始二次验证 正常模式, challenge=${challenge}, validate=${validate}, seccode=${validate}.`);
122
+ if (!this.checkParam(challenge, validate, seccode)) {
123
+ this.libResult.setAll(0, "", "正常模式,本地校验,参数challenge、validate、seccode不可为空");
124
+ } else {
125
+ const response_seccode = await this.requestValidate(challenge, validate, seccode, params);
126
+ if (!response_seccode) {
127
+ this.libResult.setAll(0, "", "请求极验validate接口失败");
128
+ } else if (response_seccode === "false") {
129
+ this.libResult.setAll(0, "", "极验二次验证不通过");
130
+ } else {
131
+ this.libResult.setAll(1, "", "");
132
+ }
133
+ }
134
+ // this.gtlog(`successValidate(): 二次验证 正常模式, lib包返回信息=${this.libResult}.`);
135
+ return this.libResult;
136
+ }
137
+
138
+ /**
139
+ * 异常流程下(即验证初始化失败,宕机模式),二次验证
140
+ * 注意:由于是宕机模式,初衷是保证验证业务不会中断正常业务,所以此处只作简单的参数校验,可自行设计逻辑。
141
+ */
142
+ failValidate(challenge, validate, seccode) {
143
+ // this.gtlog(`failValidate(): 开始二次验证 宕机模式, challenge=${challenge}, validate=${validate}, seccode=${seccode}.`);
144
+ if (!this.checkParam(challenge, validate, seccode)) {
145
+ this.libResult.setAll(0, "", "宕机模式,本地校验,参数challenge、validate、seccode不可为空.");
146
+ } else {
147
+ this.libResult.setAll(1, "", "");
148
+ }
149
+ // this.gtlog(`failValidate(): 二次验证 宕机模式, lib包返回信息=${this.libResult}.`);
150
+ return this.libResult;
151
+ }
152
+
153
+ /**
154
+ * 向极验发送二次验证的请求,POST方式
155
+ */
156
+ async requestValidate(challenge, validate, seccode, params) {
157
+ params = Object.assign(params, {
158
+ "seccode": seccode,
159
+ "json_format": GeetestLib.JSON_FORMAT,
160
+ "challenge": challenge,
161
+ "sdk": GeetestLib.VERSION,
162
+ "captchaid": this.geetest_id
163
+ });
164
+ const validate_url = GeetestLib.API_URL + GeetestLib.VALIDATE_URL;
165
+ // this.gtlog(`requestValidate(): 二次验证 正常模式, 向极验发送请求, url=${validate_url}, params=${JSON.stringify(params)}.`);
166
+ let response_seccode;
167
+ try {
168
+ const res = await axios({
169
+ url: validate_url,
170
+ method: "POST",
171
+ timeout: GeetestLib.HTTP_TIMEOUT_DEFAULT,
172
+ data: qs.stringify(params),
173
+ headers: { "Content-Type": "application/x-www-form-urlencoded" }
174
+ }).catch(err => {
175
+ // console.log(err)
176
+ });
177
+ const resBody = (res.status === 200) ? res.data : "";
178
+ // this.gtlog(`requestValidate(): 二次验证 正常模式, 与极验网络交互正常, 返回码=${res.status}, 返回body=${JSON.stringify(resBody)}.`);
179
+ response_seccode = resBody["seccode"];
180
+ } catch (e) {
181
+ // this.gtlog("requestValidate(): 二次验证 正常模式, 请求异常, " + e.message);
182
+ response_seccode = "";
183
+ }
184
+ return response_seccode;
185
+ }
186
+
187
+ /**
188
+ * 校验二次验证的三个参数,校验通过返回true,校验失败返回false
189
+ */
190
+ checkParam(challenge, validate, seccode) {
191
+ return !(challenge == undefined || challenge.trim() === "" || validate == undefined || validate.trim() === "" || seccode == undefined || seccode.trim() === "");
192
+ }
193
+
194
+ /**
195
+ * md5 加密
196
+ */
197
+ md5_encode(value) {
198
+ return crypto.createHash("md5").update(value).digest("hex");
199
+ }
200
+
201
+ /**
202
+ * sha256加密
203
+ */
204
+ sha256_encode(value) {
205
+ return crypto.createHash("sha256").update(value).digest("hex");
206
+ }
207
+
208
+ /**
209
+ * hmac-sha256 加密
210
+ */
211
+ hmac_sha256_encode(value, key) {
212
+ return crypto.createHmac("sha256", key).update(value).digest("hex");
213
+ }
214
+
215
+ }
216
+
217
+ module.exports = GeetestLib;
@@ -0,0 +1,20 @@
1
+ // sdk lib包的返回结果信息。
2
+ class GeetestLibResult {
3
+ constructor() {
4
+ this.status = 0; // 成功失败的标识码,1表示成功,0表示失败
5
+ this.data = ""; // 返回数据,json格式
6
+ this.msg = ""; // 备注信息,如异常信息等
7
+ }
8
+
9
+ setAll(status, data, msg) {
10
+ this.status = status;
11
+ this.data = data;
12
+ this.msg = msg;
13
+ }
14
+
15
+ toString() {
16
+ return `GeetestLibResult{status=${this.status}, data=${this.data}, msg=${this.msg}}`;
17
+ }
18
+ }
19
+
20
+ module.exports = GeetestLibResult;
@@ -35,7 +35,7 @@ export const sendVerificationCode = (accountsServer: AccountsServer) => async (
35
35
  res: express.Response
36
36
  ) => {
37
37
  try {
38
- const { user } = req.body;
38
+ const { user} = req.body;
39
39
  const password: any = accountsServer.getServices().password;
40
40
  const userId = await password.sendVerificationCode(user);
41
41
  res.json(userId);
@@ -2,7 +2,7 @@
2
2
  * @Author: baozhoutao@steedos.com
3
3
  * @Date: 2022-03-28 09:35:34
4
4
  * @LastEditors: baozhoutao@steedos.com
5
- * @LastEditTime: 2022-11-15 10:15:34
5
+ * @LastEditTime: 2023-03-17 15:28:17
6
6
  * @Description:
7
7
  */
8
8
  import * as express from 'express';
@@ -33,7 +33,9 @@ export const getSettings = (accountsServer: AccountsServer) => async (
33
33
  enable_email_code_login: false,
34
34
  enable_bind_mobile: false,
35
35
  enable_bind_email: false,
36
- enable_saas: validator.toBoolean(process.env.STEEDOS_TENANT_ENABLE_SAAS || 'false', true)
36
+ enable_saas: validator.toBoolean(process.env.STEEDOS_TENANT_ENABLE_SAAS || 'false', true),
37
+ enable_open_geetest: validator.toBoolean(process.env.STEEDOS_CAPTCHA_GEETEST_ENABLED || 'false')
38
+
37
39
  }
38
40
 
39
41
  if (config.tenant) {
@@ -86,6 +88,7 @@ export const getSettings = (accountsServer: AccountsServer) => async (
86
88
  root_url: process.env.ROOT_URL,
87
89
  already_mail_service: already_mail_service,
88
90
  already_sms_service: already_sms_service,
89
- serverInitInfo: serverInitInfo
91
+ serverInitInfo: serverInitInfo,
92
+ redirect_url_whitelist: process.env.REDIRECT_URL_WHITELIST
90
93
  })
91
94
  }
@@ -24,6 +24,7 @@ import { changeUserFullname } from './endpoints/put-user-name';
24
24
  import { login } from './endpoints/login';
25
25
  import { getMySpaces } from './endpoints/spaces';
26
26
  import { verify_email, verify_mobile} from './endpoints/password/verify';
27
+ import { geetest_init,geetest_validate } from './endpoints/geetestV3/geetest-init'
27
28
 
28
29
 
29
30
  const defaultOptions: AccountsExpressOptions = {
@@ -65,6 +66,7 @@ const accountsExpress = (
65
66
 
66
67
  router.post(`${path}/:service/session`, userLoader(accountsServer), updateSession(accountsServer));
67
68
 
69
+
68
70
  const services = accountsServer.getServices();
69
71
 
70
72
  // @accounts/password
@@ -80,13 +82,15 @@ const accountsExpress = (
80
82
 
81
83
  router.post(`${path}/password/sendVerificationEmail`, sendVerificationEmail(accountsServer));
82
84
 
83
- router.post(`${path}/password/sendVerificationCode`, sendVerificationCode(accountsServer));
85
+ router.post(`${path}/password/sendVerificationCode`,geetest_validate, sendVerificationCode(accountsServer));
84
86
 
85
87
  router.post(`${path}/password/sendResetPasswordEmail`, sendResetPasswordEmail(accountsServer));
86
88
 
87
89
  router.post(`${path}/password/verify/email`, userLoader(accountsServer), verify_email(accountsServer));
88
90
  router.post(`${path}/password/verify/mobile`, userLoader(accountsServer), verify_mobile(accountsServer));
89
91
 
92
+ router.post(`${path}/geetest/geetest-init`, geetest_init(accountsServer));
93
+
90
94
  router.post(
91
95
  `${path}/password/changePassword`,
92
96
  userLoader(accountsServer),