@kevisual/api 0.0.6 → 0.0.8
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/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kevisual/api",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.8",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "mod.ts",
|
|
6
6
|
"scripts": {
|
|
@@ -35,5 +35,13 @@
|
|
|
35
35
|
"@kevisual/load": "^0.0.6",
|
|
36
36
|
"es-toolkit": "^1.43.0",
|
|
37
37
|
"nanoid": "^5.1.6"
|
|
38
|
+
},
|
|
39
|
+
"exports": {
|
|
40
|
+
".": "./mod.ts",
|
|
41
|
+
"./login": "./query/query-login/query-login-browser.ts",
|
|
42
|
+
"./login-node": "./query/query-login/query-login-node.ts",
|
|
43
|
+
"./config": "./query/query-config/query-config.ts",
|
|
44
|
+
"./proxy": "./query/query-proxy/index.ts",
|
|
45
|
+
"./query/**/*.ts": "./query/**/*.ts"
|
|
38
46
|
}
|
|
39
47
|
}
|
|
@@ -425,15 +425,23 @@ import MD5 from 'crypto-js/md5.js';
|
|
|
425
425
|
import jsonwebtoken from 'jsonwebtoken';
|
|
426
426
|
|
|
427
427
|
*/
|
|
428
|
-
loginWithWeb(baseURL: string, { MD5, jsonwebtoken }: { MD5
|
|
428
|
+
loginWithWeb(baseURL: string, { MD5, jsonwebtoken }: { MD5?: any; jsonwebtoken?: any }) {
|
|
429
429
|
const randomId = Math.random().toString(36).substring(2, 15);
|
|
430
430
|
const timestamp = Date.now();
|
|
431
431
|
const tokenSecret = 'xiao' + randomId;
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
432
|
+
let sign = '';
|
|
433
|
+
if (MD5) {
|
|
434
|
+
sign = MD5(`${tokenSecret}${timestamp}`).toString();
|
|
435
|
+
}
|
|
436
|
+
let token = '';
|
|
437
|
+
if (jsonwebtoken) {
|
|
438
|
+
token = jsonwebtoken.sign({ randomId, timestamp, sign }, tokenSecret, {
|
|
439
|
+
// 10分钟过期
|
|
440
|
+
expiresIn: 60 * 10, // 10分钟
|
|
441
|
+
});
|
|
442
|
+
} else {
|
|
443
|
+
token = tokenSecret;
|
|
444
|
+
}
|
|
437
445
|
const url = `${baseURL}/api/router?path=user&key=webLogin&p&loginToken=${token}&sign=${sign}&randomId=${randomId}`;
|
|
438
446
|
return { url, token, tokenSecret };
|
|
439
447
|
}
|
|
@@ -471,12 +479,13 @@ await pollLoginStatus(res.token, { tokenSecret: res.tokenSecret });
|
|
|
471
479
|
if (res.code === 200 && res.data?.code === 200) {
|
|
472
480
|
try {
|
|
473
481
|
console.log('网页登录成功');
|
|
474
|
-
return;
|
|
482
|
+
return true;
|
|
475
483
|
} catch (error) {
|
|
476
484
|
console.log('登录失败', error);
|
|
477
|
-
return;
|
|
485
|
+
return false;
|
|
478
486
|
}
|
|
479
487
|
}
|
|
480
488
|
console.log('登录失败', res);
|
|
489
|
+
return false;
|
|
481
490
|
}
|
|
482
491
|
}
|