@steedos/accounts 2.4.3 → 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.
- package/lib/rest-express/endpoints/geetestV3/geetest-init.js +157 -0
- package/lib/rest-express/endpoints/geetestV3/geetest-init.js.map +1 -0
- package/lib/rest-express/endpoints/geetestV3/sdk/geetest_config.js +11 -0
- package/lib/rest-express/endpoints/geetestV3/sdk/geetest_config.js.map +1 -0
- package/lib/rest-express/endpoints/geetestV3/sdk/geetest_lib.js +211 -0
- package/lib/rest-express/endpoints/geetestV3/sdk/geetest_lib.js.map +1 -0
- package/lib/rest-express/endpoints/geetestV3/sdk/geetest_lib_result.js +18 -0
- package/lib/rest-express/endpoints/geetestV3/sdk/geetest_lib_result.js.map +1 -0
- package/lib/rest-express/endpoints/password/verify-email.js.map +1 -1
- package/lib/rest-express/endpoints/steedos/settings.js +1 -0
- package/lib/rest-express/endpoints/steedos/settings.js.map +1 -1
- package/lib/rest-express/express-middleware.js +3 -1
- package/lib/rest-express/express-middleware.js.map +1 -1
- package/package.json +8 -6
- package/src/rest-express/endpoints/geetestV3/geetest-init.ts +125 -0
- package/src/rest-express/endpoints/geetestV3/sdk/geetest_config.js +11 -0
- package/src/rest-express/endpoints/geetestV3/sdk/geetest_lib.js +217 -0
- package/src/rest-express/endpoints/geetestV3/sdk/geetest_lib_result.js +20 -0
- package/src/rest-express/endpoints/password/verify-email.ts +1 -1
- package/src/rest-express/endpoints/steedos/settings.ts +2 -0
- package/src/rest-express/express-middleware.ts +5 -1
|
@@ -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":"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"}
|
|
@@ -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,
|
|
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"}
|
|
@@ -28,6 +28,7 @@ var getSettings = function (accountsServer) { return function (req, res) { retur
|
|
|
28
28
|
enable_bind_mobile: false,
|
|
29
29
|
enable_bind_email: false,
|
|
30
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);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"settings.js","sourceRoot":"","sources":["../../../../src/rest-express/endpoints/steedos/settings.ts"],"names":[],"mappings":";;;;AAQA,0BAA4B;AAE5B,8CAAsE;AACtE,kCAAiC;AACjC,sCAA4E;AAC5E,IAAM,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;AAEvC,IAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;AAE/B,IAAM,MAAM,GAAG,IAAA,2BAAgB,GAAE,CAAC;AAE3B,IAAM,WAAW,GAAG,UAAC,cAA8B,IAAK,OAAA,UAC3D,GAAoB,EACpB,GAAqB;;;;;;gBAEnB,MAAM,GAAQ;oBAChB,IAAI,EAAE,SAAS;oBACf,QAAQ,EAAE,SAAS;oBACnB,cAAc,EAAE,SAAS;oBACzB,oBAAoB,EAAE,IAAI;oBAC1B,eAAe,EAAE,IAAI;oBACrB,sBAAsB,EAAE,IAAI;oBAC5B,qBAAqB,EAAE,IAAI;oBAC3B,wBAAwB,EAAE,KAAK;oBAC/B,uBAAuB,EAAE,KAAK;oBAC9B,kBAAkB,EAAE,KAAK;oBACzB,iBAAiB,EAAE,KAAK;oBACxB,WAAW,EAAE,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,0BAA0B,IAAI,OAAO,EAAE,IAAI,CAAC;
|
|
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":";;;AAAA,yEAAuE;AACvE,oDAAmF;AACnF,kEAA6G;AAE7G,4CAA8C;AAC9C,IAAI,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;AAEtC,yEAAsE;AACtE,iDAA+C;AAC/C,uDAAsD;AACtD,mDAAkD;AAClD,6CAA4C;AAC5C,yEAAuE;AACvE,6DAA2D;AAC3D,0DAAiE;AAEjE,wEAAsE;AACtE,6CAA2C;AAE3C,6DAA2D;AAE3D,yDAA2D;AAC3D,2DAA+D;AAC/D,2CAA0C;AAC1C,6CAAiD;AACjD,sDAAyE;
|
|
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.
|
|
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.
|
|
58
|
-
"@steedos/meteor-bundle-runner": "2.4.
|
|
59
|
-
"@steedos/objectql": "2.4.
|
|
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.
|
|
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": "
|
|
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
|
|
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);
|
|
@@ -34,6 +34,8 @@ export const getSettings = (accountsServer: AccountsServer) => async (
|
|
|
34
34
|
enable_bind_mobile: false,
|
|
35
35
|
enable_bind_email: false,
|
|
36
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) {
|
|
@@ -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),
|