mas-server 2.0.4 → 2.0.5
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/.temp/merge/validType.ts +98 -0
- package/dist/index.js +8 -47
- package/dist/src/index.js +100 -0
- package/dist/src/state.js +4 -0
- package/dist/src/typings/index.js +2 -0
- package/dist/src/utils/apiDoc.js +33 -0
- package/dist/src/utils/createRouter.js +51 -0
- package/dist/src/utils/getLog.js +18 -0
- package/dist/src/utils/getRouterInfo.js +34 -0
- package/dist/src/utils/masUtils.js +12 -0
- package/dist/src/utils/meaToken.js +57 -0
- package/dist/src/utils/quickSend.js +32 -0
- package/dist/src/utils/readApi.js +50 -0
- package/dist/src/utils/validRouteData.js +37 -0
- package/dist/src/utils/validToken.js +24 -0
- package/dist/src/utils/validType.js +84 -0
- package/dist/test/apiTemplate/api.temp.js +24 -0
- package/dist/test/apiTemplate/curd/del.js +21 -0
- package/dist/test/apiTemplate/curd/get.js +21 -0
- package/dist/test/apiTemplate/curd/set.js +21 -0
- package/dist/test/config/config.js +31 -0
- package/dist/test/config/createSqlFormData.js +15 -0
- package/dist/test/config/defaultApiConfig.js +7 -0
- package/dist/test/config/docNav.js +0 -0
- package/dist/test/main.js +31 -0
- package/dist/test/scripts/beforeCreated.js +62 -0
- package/dist/test/scripts/createApiFile.js +52 -0
- package/dist/test/scripts/createApis.js +81 -0
- package/dist/test/scripts/createSqlForm.js +10 -0
- package/dist/test/scripts/getSqlFormType.js +56 -0
- package/dist/test/scripts/run.js +6 -0
- package/dist/test/src/api/example/ArrValid.js +21 -0
- package/dist/test/src/api/example/per.js +37 -0
- package/dist/test/src/api/example/tip.js +22 -0
- package/dist/test/src/api/example/validReqData.js +98 -0
- package/dist/test/src/api/index.js +24 -0
- package/dist/test/src/debug.js +10 -0
- package/dist/test/src/masState.js +4 -0
- package/dist/test/src/sql/selectStudent.js +10 -0
- package/dist/test/src/sqlform.json +1 -0
- package/dist/test/test.js +3 -0
- package/dist/utils/apiDoc.js +17 -2
- package/dist/utils/createRouter.js +51 -0
- package/dist/utils/getRouterInfo.js +34 -0
- package/dist/utils/validRouteData.js +1 -1
- package/dist/utils/validToken.js +1 -1
- package/dist/utils/validType.js +0 -17
- package/package.json +5 -5
- package/{dist/apiDoc/assets/empty-907982e4.js → src/apiDoc/assets/empty-a6de4920.js} +1 -1
- package/src/apiDoc/assets/index-be53fe8f.css +6 -0
- package/src/apiDoc/assets/index-f9ab4187.js +1427 -0
- package/src/apiDoc/assets/jsoneditor-icons-45c98bf0.svg +749 -749
- package/src/apiDoc/index.html +2 -2
- package/src/index.ts +20 -24
- package/src/typings/index.ts +5 -5
- package/src/utils/apiDoc.ts +18 -2
- package/src/utils/createRouter.ts +22 -0
- package/src/utils/getRouterInfo.ts +28 -0
- package/src/utils/readApi.ts +0 -2
- package/src/utils/validRouteData.ts +1 -2
- package/src/utils/validToken.ts +1 -1
- package/src/utils/validType.ts +0 -17
- package/test/apiTemplate/api.temp.ts +8 -3
- package/test/config/config.ts +1 -1
- package/test/config/defaultApiConfig.ts +7 -0
- package/test/config/docNav.ts +0 -0
- package/test/main.ts +1 -0
- package/test/scripts/beforeCreated.ts +2 -41
- package/test/scripts/createApiFile.ts +0 -1
- package/test/scripts/createApis.ts +0 -48
- package/test/scripts/getSqlFormType.ts +2 -13
- package/test/src/api/example/ArrValid.ts +11 -0
- package/test/src/api/example/per.ts +34 -0
- package/test/src/api/example/tip.ts +9 -0
- package/test/src/api/example/validReqData.ts +85 -0
- package/test/src/api/index.ts +8 -1
- package/test/src/debug.ts +3 -50
- package/test/src/sqlform.json +1 -12
- package/test/test.ts +0 -12
- package/test//345/276/205/345/274/200/345/217/221.md +12 -6
- package/tsconfig-build.json +20 -0
- package/tsconfig.json +1 -3
- package/.temp/validType.ts +0 -96
- package/dist/apiDoc/assets/index-b56e6bc6.js +0 -1414
- package/dist/apiDoc/assets/index-bb16d834.css +0 -6
- package/dist/apiDoc/assets/jsoneditor-icons-45c98bf0.svg +0 -749
- package/dist/apiDoc/favicon.ico +0 -0
- package/dist/apiDoc/index.html +0 -15
- package/dist/utils/getRouteByApiSrc.js +0 -54
- package/dist/utils/mas-encrypt.min.js +0 -3072
- package/src/apiDoc/assets/empty-907982e4.js +0 -1
- package/src/apiDoc/assets/index-b56e6bc6.js +0 -1414
- package/src/apiDoc/assets/index-bb16d834.css +0 -6
- package/test/config/api.config.ts +0 -3
- package/test/config/api.key.ts +0 -14
- package/test/src/api/curd/student/del.ts +0 -9
- package/test/src/api/curd/student/get.ts +0 -9
- package/test/src/api/curd/student/set.ts +0 -9
- package/test/src/api/per.ts +0 -6
- package/test/src/api/person/del.ts +0 -4
- package/test/src/api/person/get.ts +0 -4
- package/test/src/api/person/set.ts +0 -4
- package/test/src/api/test.ts +0 -7
- package/test/src/api/validtest/boolArr.ts +0 -4
- package/test/typings/studentSF.ts +0 -6
- package/test/typings/test11SF.ts +0 -1
- package/test/typings/test22SF.ts +0 -1
- package/test/typings/testformSF.ts +0 -1
- /package/.temp/{logs/.keep → .keep} +0 -0
- /package/{src/utils → .temp}/getRouteByApiSrc.ts +0 -0
- /package/.temp/{a.ts → merge/a.ts} +0 -0
- /package/.temp/{as.ts → merge/as.ts} +0 -0
- /package/.temp/{b.ts → merge/b.ts} +0 -0
- /package/.temp/{i.js → merge/i.js} +0 -0
- /package/{test/typings → .temp/merge/logs}/.keep +0 -0
- /package/.temp/{test.ts → merge/test.ts} +0 -0
- /package/.temp/{validType copy.ts → merge/validType copy.ts} +0 -0
- /package/.temp/{validTypeOptimize.ts → merge/validTypeOptimize.ts} +0 -0
- /package/{test/scripts → .temp}/updateRouter.ts +0 -0
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { getType } from "../utils/masUtils";
|
|
2
|
+
|
|
3
|
+
type BasicTypeDescriptor =
|
|
4
|
+
| StringConstructor
|
|
5
|
+
| NumberConstructor
|
|
6
|
+
| BooleanConstructor
|
|
7
|
+
| ObjectConstructor;
|
|
8
|
+
type TypeDescriptor = BasicTypeDescriptor | Array<any>;
|
|
9
|
+
|
|
10
|
+
interface TypeMapping {
|
|
11
|
+
[key: string]:
|
|
12
|
+
| TypeDescriptor
|
|
13
|
+
| TypeMapping
|
|
14
|
+
| Array<TypeDescriptor | TypeMapping>;
|
|
15
|
+
}
|
|
16
|
+
const vliadBase = (obj, typeMapping) => {
|
|
17
|
+
return getType(obj) == (typeMapping as any).name.toLowerCase();
|
|
18
|
+
};
|
|
19
|
+
const validTypeObj = (obj: any, typeMapping: TypeMapping | TypeDescriptor) => {
|
|
20
|
+
if (obj === null || obj === undefined) return false;
|
|
21
|
+
let typeT = getType(typeMapping);
|
|
22
|
+
if (typeT == "function") {
|
|
23
|
+
return vliadBase(obj, typeMapping);
|
|
24
|
+
} else if (typeT == "object") {
|
|
25
|
+
if (getType(obj) !== "object") return false;
|
|
26
|
+
for (let k in typeMapping) {
|
|
27
|
+
if (obj[k] === null || obj[k] === undefined) return false;
|
|
28
|
+
if (!validType(obj[k], typeMapping[k])) return false;
|
|
29
|
+
}
|
|
30
|
+
} else if (typeT == "array") {
|
|
31
|
+
if (getType(obj) != "array") return false;
|
|
32
|
+
if (obj.length === 0) return false;
|
|
33
|
+
const typeMappingArrObj = typeMapping[0];
|
|
34
|
+
if (!typeMappingArrObj) {
|
|
35
|
+
throw new Error(`非法的效验格式 ${typeMapping} ${typeMappingArrObj}`);
|
|
36
|
+
}
|
|
37
|
+
if (getType(obj) != "array") return false;
|
|
38
|
+
for (let v of obj) {
|
|
39
|
+
if (!validTypeObj(v, typeMappingArrObj)) return false;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return true;
|
|
43
|
+
};
|
|
44
|
+
const validTypeObjStrict = (
|
|
45
|
+
obj: any,
|
|
46
|
+
typeMapping: TypeMapping | TypeDescriptor
|
|
47
|
+
) => {
|
|
48
|
+
if (obj === null || obj === undefined) return false;
|
|
49
|
+
let typeT = getType(typeMapping);
|
|
50
|
+
if (typeT == "function") {
|
|
51
|
+
return vliadBase(obj, typeMapping);
|
|
52
|
+
} else if (typeT == "object") {
|
|
53
|
+
if (getType(obj) !== "object") return false;
|
|
54
|
+
if (Object.keys(obj).length != Object.keys(typeT).length) return false;
|
|
55
|
+
for (let k in typeMapping) {
|
|
56
|
+
if (obj[k] === null || obj[k] === undefined) return false;
|
|
57
|
+
if (!validType(obj[k], typeMapping[k])) return false;
|
|
58
|
+
}
|
|
59
|
+
} else if (typeT == "array") {
|
|
60
|
+
if (getType(obj) != "array") return false;
|
|
61
|
+
if (obj.length === 0) return false;
|
|
62
|
+
const typeMappingArrObj = typeMapping[0];
|
|
63
|
+
if (!typeMappingArrObj) {
|
|
64
|
+
throw new Error(`非法的效验格式 ${typeMapping} ${typeMappingArrObj}`);
|
|
65
|
+
}
|
|
66
|
+
if (getType(obj) != "array") return false;
|
|
67
|
+
for (let v of obj) {
|
|
68
|
+
if (!validTypeObj(v, typeMappingArrObj)) return false;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return true;
|
|
72
|
+
};
|
|
73
|
+
export default function validType(
|
|
74
|
+
obj: any,
|
|
75
|
+
typeMapping: TypeMapping | TypeDescriptor,
|
|
76
|
+
strict: boolean = false
|
|
77
|
+
): boolean {
|
|
78
|
+
return strict
|
|
79
|
+
? validTypeObjStrict(obj, typeMapping)
|
|
80
|
+
: validTypeObj(obj, typeMapping);
|
|
81
|
+
}
|
|
82
|
+
// let res = validType(
|
|
83
|
+
// { name: "2", arr: [1] },
|
|
84
|
+
// { name: String, arr: [Number] },
|
|
85
|
+
// true
|
|
86
|
+
// [
|
|
87
|
+
// { name: "s", age: "" },
|
|
88
|
+
// { names: "s", age: "" },
|
|
89
|
+
// ],
|
|
90
|
+
// { name: "11", age: 1, obj: { a: "1", b: 1 } },
|
|
91
|
+
// String,
|
|
92
|
+
// Boolean,
|
|
93
|
+
// { name: String, age: Number, obj: { a: String, b: Number } }
|
|
94
|
+
// [{ name: String }]
|
|
95
|
+
// );
|
|
96
|
+
// console.log(res);
|
|
97
|
+
// console.log(getType(null)); //"null"
|
|
98
|
+
// console.log(getType(undefined)); //"undefined"
|
package/dist/index.js
CHANGED
|
@@ -1,45 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
2
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
4
|
};
|
|
28
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.validType = exports.createToken = exports.validToken = exports.massql = exports.getsqlFormDataType = exports.getsqlFormData = exports.createSqlForm = exports.checkSqlKey = exports.sqlQuery = exports.sqlInit = exports.sqlEnd = exports.sqlState = exports.moment = exports.
|
|
6
|
+
exports.validType = exports.createToken = exports.validToken = exports.massql = exports.getsqlFormDataType = exports.getsqlFormData = exports.createSqlForm = exports.checkSqlKey = exports.sqlQuery = exports.sqlInit = exports.sqlEnd = exports.sqlState = exports.moment = exports.readApi = exports.getApp = void 0;
|
|
30
7
|
require("module-alias/register");
|
|
31
8
|
const express_1 = __importDefault(require("express"));
|
|
32
9
|
const cors_1 = __importDefault(require("cors"));
|
|
33
10
|
const path_1 = __importDefault(require("path"));
|
|
34
|
-
const fs = __importStar(require("fs"));
|
|
35
11
|
const state_1 = require("./state");
|
|
36
12
|
const getLog_1 = __importDefault(require("./utils/getLog"));
|
|
37
13
|
const quickSend_1 = __importDefault(require("./utils/quickSend"));
|
|
38
14
|
const readApi_1 = __importDefault(require("./utils/readApi"));
|
|
39
15
|
exports.readApi = readApi_1.default;
|
|
40
16
|
const validRouteData_1 = __importDefault(require("./utils/validRouteData"));
|
|
41
|
-
const getRouteByApiSrc_1 = __importDefault(require("./utils/getRouteByApiSrc"));
|
|
42
|
-
exports.getRouteByApiSrc = getRouteByApiSrc_1.default;
|
|
43
17
|
const validToken_1 = __importDefault(require("./utils/validToken"));
|
|
44
18
|
const ansi_colors_1 = __importDefault(require("ansi-colors"));
|
|
45
19
|
const moment_1 = __importDefault(require("moment"));
|
|
@@ -63,16 +37,17 @@ Object.defineProperty(exports, "createToken", { enumerable: true, get: function
|
|
|
63
37
|
Object.defineProperty(exports, "validToken", { enumerable: true, get: function () { return meaToken_1.validToken; } });
|
|
64
38
|
const validType_1 = __importDefault(require("./utils/validType"));
|
|
65
39
|
exports.validType = validType_1.default;
|
|
40
|
+
const createRouter_1 = __importDefault(require("./utils/createRouter"));
|
|
41
|
+
const getRouterInfo_1 = __importDefault(require("./utils/getRouterInfo"));
|
|
66
42
|
// =================================================================
|
|
67
43
|
function getApp(DIRNAME, beforeMounted) {
|
|
68
44
|
// 路径和配置放入state
|
|
69
45
|
state_1.state.DIRNAME = DIRNAME;
|
|
70
46
|
const config = require(path_1.default.join(DIRNAME, "/config/config.ts")).default;
|
|
71
|
-
|
|
72
|
-
|
|
47
|
+
// 获取路由信息
|
|
48
|
+
(0, getRouterInfo_1.default)(path_1.default.join(state_1.state.DIRNAME, "src/api"), path_1.default.join(state_1.state.DIRNAME, "config/defaultApiConfig.ts"));
|
|
73
49
|
state_1.state.config = config;
|
|
74
|
-
state_1.state.
|
|
75
|
-
state_1.state.apiCN = apiCN;
|
|
50
|
+
state_1.state.apiCN = [];
|
|
76
51
|
// new express
|
|
77
52
|
const app = (0, express_1.default)();
|
|
78
53
|
// 是否允许跨域
|
|
@@ -83,7 +58,6 @@ function getApp(DIRNAME, beforeMounted) {
|
|
|
83
58
|
// 初始化app
|
|
84
59
|
app.use(express_1.default.urlencoded({ extended: true }));
|
|
85
60
|
app.use(express_1.default.json());
|
|
86
|
-
// 自定义中间件来处理纯文本和JSON数据
|
|
87
61
|
// 错误处理中间件
|
|
88
62
|
app.use((err, req, res, next) => {
|
|
89
63
|
if (err.type == "entity.parse.failed") {
|
|
@@ -109,21 +83,8 @@ function getApp(DIRNAME, beforeMounted) {
|
|
|
109
83
|
app.use("/apidoc", express_1.default.static(path_1.default.join(__dirname, "/apiDoc")));
|
|
110
84
|
(0, apiDoc_1.default)(app);
|
|
111
85
|
}
|
|
112
|
-
//
|
|
113
|
-
|
|
114
|
-
let isExist = fs.existsSync(path_1.default.join(DIRNAME, "src", item) + ".ts");
|
|
115
|
-
if (!isExist) {
|
|
116
|
-
console.info(ansi_colors_1.default.red(`${item} not found`));
|
|
117
|
-
continue;
|
|
118
|
-
}
|
|
119
|
-
const apiFunc = require(path_1.default.join(DIRNAME, "src", item)).default;
|
|
120
|
-
if (!apiFunc) {
|
|
121
|
-
console.info(ansi_colors_1.default.yellow(`${item} 没有导出函数,已跳过..`));
|
|
122
|
-
}
|
|
123
|
-
else {
|
|
124
|
-
apiFunc && app[Router[item].methods](item, apiFunc);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
86
|
+
// 创建路由
|
|
87
|
+
(0, createRouter_1.default)(app);
|
|
127
88
|
// 运行debug
|
|
128
89
|
setTimeout(() => {
|
|
129
90
|
try {
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.validType = exports.createToken = exports.validToken = exports.massql = exports.getsqlFormDataType = exports.getsqlFormData = exports.createSqlForm = exports.checkSqlKey = exports.sqlQuery = exports.sqlInit = exports.sqlEnd = exports.sqlState = exports.moment = exports.readApi = exports.getApp = void 0;
|
|
7
|
+
require("module-alias/register");
|
|
8
|
+
const express_1 = __importDefault(require("express"));
|
|
9
|
+
const cors_1 = __importDefault(require("cors"));
|
|
10
|
+
const path_1 = __importDefault(require("path"));
|
|
11
|
+
const state_1 = require("./state");
|
|
12
|
+
const getLog_1 = __importDefault(require("./utils/getLog"));
|
|
13
|
+
const quickSend_1 = __importDefault(require("./utils/quickSend"));
|
|
14
|
+
const readApi_1 = __importDefault(require("./utils/readApi"));
|
|
15
|
+
exports.readApi = readApi_1.default;
|
|
16
|
+
const validRouteData_1 = __importDefault(require("./utils/validRouteData"));
|
|
17
|
+
const validToken_1 = __importDefault(require("./utils/validToken"));
|
|
18
|
+
const ansi_colors_1 = __importDefault(require("ansi-colors"));
|
|
19
|
+
const moment_1 = __importDefault(require("moment"));
|
|
20
|
+
exports.moment = moment_1.default;
|
|
21
|
+
require("moment/locale/zh-cn");
|
|
22
|
+
moment_1.default.locale("zh-cn");
|
|
23
|
+
// 数据库
|
|
24
|
+
const masmysql_1 = require("masmysql");
|
|
25
|
+
Object.defineProperty(exports, "sqlEnd", { enumerable: true, get: function () { return masmysql_1.sqlEnd; } });
|
|
26
|
+
Object.defineProperty(exports, "sqlInit", { enumerable: true, get: function () { return masmysql_1.sqlInit; } });
|
|
27
|
+
Object.defineProperty(exports, "sqlQuery", { enumerable: true, get: function () { return masmysql_1.sqlQuery; } });
|
|
28
|
+
Object.defineProperty(exports, "checkSqlKey", { enumerable: true, get: function () { return masmysql_1.checkSqlKey; } });
|
|
29
|
+
Object.defineProperty(exports, "createSqlForm", { enumerable: true, get: function () { return masmysql_1.createSqlForm; } });
|
|
30
|
+
Object.defineProperty(exports, "massql", { enumerable: true, get: function () { return masmysql_1.massql; } });
|
|
31
|
+
Object.defineProperty(exports, "sqlState", { enumerable: true, get: function () { return masmysql_1.state; } });
|
|
32
|
+
Object.defineProperty(exports, "getsqlFormDataType", { enumerable: true, get: function () { return masmysql_1.getsqlFormDataType; } });
|
|
33
|
+
Object.defineProperty(exports, "getsqlFormData", { enumerable: true, get: function () { return masmysql_1.getsqlFormData; } });
|
|
34
|
+
const apiDoc_1 = __importDefault(require("./utils/apiDoc"));
|
|
35
|
+
const meaToken_1 = require("./utils/meaToken");
|
|
36
|
+
Object.defineProperty(exports, "createToken", { enumerable: true, get: function () { return meaToken_1.createToken; } });
|
|
37
|
+
Object.defineProperty(exports, "validToken", { enumerable: true, get: function () { return meaToken_1.validToken; } });
|
|
38
|
+
const validType_1 = __importDefault(require("./utils/validType"));
|
|
39
|
+
exports.validType = validType_1.default;
|
|
40
|
+
const createRouter_1 = __importDefault(require("./utils/createRouter"));
|
|
41
|
+
const getRouterInfo_1 = __importDefault(require("./utils/getRouterInfo"));
|
|
42
|
+
// =================================================================
|
|
43
|
+
function getApp(DIRNAME, beforeMounted) {
|
|
44
|
+
// 路径和配置放入state
|
|
45
|
+
state_1.state.DIRNAME = DIRNAME;
|
|
46
|
+
const config = require(path_1.default.join(DIRNAME, "/config/config.ts")).default;
|
|
47
|
+
// 获取路由信息
|
|
48
|
+
(0, getRouterInfo_1.default)(path_1.default.join(state_1.state.DIRNAME, "src/api"), path_1.default.join(state_1.state.DIRNAME, "config/defaultApiConfig.ts"));
|
|
49
|
+
state_1.state.config = config;
|
|
50
|
+
state_1.state.apiCN = [];
|
|
51
|
+
// new express
|
|
52
|
+
const app = (0, express_1.default)();
|
|
53
|
+
// 是否允许跨域
|
|
54
|
+
config.cors && app.use((0, cors_1.default)());
|
|
55
|
+
if (beforeMounted) {
|
|
56
|
+
beforeMounted(app);
|
|
57
|
+
}
|
|
58
|
+
// 初始化app
|
|
59
|
+
app.use(express_1.default.urlencoded({ extended: true }));
|
|
60
|
+
app.use(express_1.default.json());
|
|
61
|
+
// 错误处理中间件
|
|
62
|
+
app.use((err, req, res, next) => {
|
|
63
|
+
if (err.type == "entity.parse.failed") {
|
|
64
|
+
req.body._str = err.body;
|
|
65
|
+
}
|
|
66
|
+
next();
|
|
67
|
+
});
|
|
68
|
+
//快速return
|
|
69
|
+
app.use(quickSend_1.default);
|
|
70
|
+
// 日志
|
|
71
|
+
if (config.logs.open) {
|
|
72
|
+
app.use(require("express-ip")().getIpInfoMiddleware);
|
|
73
|
+
app.use(getLog_1.default);
|
|
74
|
+
}
|
|
75
|
+
// 权限管理
|
|
76
|
+
if (config.token.open) {
|
|
77
|
+
app.use(validToken_1.default);
|
|
78
|
+
}
|
|
79
|
+
// 数据效验
|
|
80
|
+
app.use(validRouteData_1.default);
|
|
81
|
+
// 使用接口文档
|
|
82
|
+
if (config.apidoc) {
|
|
83
|
+
app.use("/apidoc", express_1.default.static(path_1.default.join(__dirname, "/apiDoc")));
|
|
84
|
+
(0, apiDoc_1.default)(app);
|
|
85
|
+
}
|
|
86
|
+
// 创建路由
|
|
87
|
+
(0, createRouter_1.default)(app);
|
|
88
|
+
// 运行debug
|
|
89
|
+
setTimeout(() => {
|
|
90
|
+
try {
|
|
91
|
+
require(path_1.default.join(DIRNAME + "/src/debug"));
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
console.info(ansi_colors_1.default.red("debug.js报错!!!"));
|
|
95
|
+
console.info(error);
|
|
96
|
+
}
|
|
97
|
+
}, config.debugTime || 1000);
|
|
98
|
+
return app;
|
|
99
|
+
}
|
|
100
|
+
exports.getApp = getApp;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const state_1 = require("../state");
|
|
4
|
+
exports.default = (app) => {
|
|
5
|
+
const router = JSON.stringify(state_1.state.Router, (key, value) => {
|
|
6
|
+
if (typeof value === "function") {
|
|
7
|
+
return value.toString().replace(/function\s+(\w+)\(\)\s+\{.*\}/, "$1");
|
|
8
|
+
}
|
|
9
|
+
return value;
|
|
10
|
+
});
|
|
11
|
+
const newRouter = JSON.parse(router);
|
|
12
|
+
// 有的描述没有类型,尝试从validFormat里取
|
|
13
|
+
for (const key in newRouter) {
|
|
14
|
+
const item = newRouter[key];
|
|
15
|
+
if (item.validFormat && item.validFormatDes) {
|
|
16
|
+
for (const validFormatDesItem of item.validFormatDes) {
|
|
17
|
+
if (!validFormatDesItem.type &&
|
|
18
|
+
item.validFormat[validFormatDesItem.name]) {
|
|
19
|
+
validFormatDesItem.type = item.validFormat[validFormatDesItem.name];
|
|
20
|
+
}
|
|
21
|
+
else if (!validFormatDesItem.type) {
|
|
22
|
+
validFormatDesItem.type = "String";
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
app.post("/apidoc/router", (req, res) => {
|
|
28
|
+
res.return(newRouter);
|
|
29
|
+
});
|
|
30
|
+
app.post("/apidoc/cn", (req, res) => {
|
|
31
|
+
res.return(state_1.state.apiCN);
|
|
32
|
+
});
|
|
33
|
+
};
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const state_1 = require("@/state");
|
|
30
|
+
const path_1 = __importDefault(require("path"));
|
|
31
|
+
const fs = __importStar(require("fs"));
|
|
32
|
+
const ansi_colors_1 = __importDefault(require("ansi-colors"));
|
|
33
|
+
function createRouter(app) {
|
|
34
|
+
const { Router, DIRNAME } = state_1.state;
|
|
35
|
+
// 遍历api路由
|
|
36
|
+
for (const item in Router) {
|
|
37
|
+
let isExist = fs.existsSync(path_1.default.join(DIRNAME, "src", item) + ".ts");
|
|
38
|
+
if (!isExist) {
|
|
39
|
+
console.info(ansi_colors_1.default.red(`${item} not found`));
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
42
|
+
const apiFunc = require(path_1.default.join(DIRNAME, "src", item)).default;
|
|
43
|
+
if (!apiFunc) {
|
|
44
|
+
console.info(ansi_colors_1.default.yellow(`${item} 没有导出函数,已跳过..`));
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
apiFunc && app[Router[item].methods](item, apiFunc);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
exports.default = createRouter;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const fs_1 = __importDefault(require("fs"));
|
|
7
|
+
const state_1 = require("../state");
|
|
8
|
+
const moment_1 = __importDefault(require("moment"));
|
|
9
|
+
exports.default = (req, res, next) => {
|
|
10
|
+
const { config } = state_1.state;
|
|
11
|
+
const date = (0, moment_1.default)().format("YYYY-MM-DD HH:mm:ss");
|
|
12
|
+
const data = `${date} ${req.method} ${req.ipInfo.ip} ${req.url} ${req.body ? JSON.stringify(req.body) : ""}\n`;
|
|
13
|
+
fs_1.default.appendFileSync(state_1.state.DIRNAME + `/logs/${(0, moment_1.default)().format("YYYY-MM-DD")}.log`, data);
|
|
14
|
+
if (config.logs.debug) {
|
|
15
|
+
console.info(data);
|
|
16
|
+
}
|
|
17
|
+
next();
|
|
18
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const state_1 = require("@/state");
|
|
7
|
+
const readApi_1 = __importDefault(require("./readApi"));
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const fs_1 = __importDefault(require("fs"));
|
|
10
|
+
const ansi_colors_1 = __importDefault(require("ansi-colors"));
|
|
11
|
+
function getRouterInfo(apiDir, defaullConfigDir) {
|
|
12
|
+
const apiConfig = {};
|
|
13
|
+
const { DIRNAME } = state_1.state;
|
|
14
|
+
const routerDir = (0, readApi_1.default)(apiDir, "api");
|
|
15
|
+
const defaullConfig = require(defaullConfigDir).default;
|
|
16
|
+
// 遍历api路由
|
|
17
|
+
for (const item of routerDir) {
|
|
18
|
+
let isExist = fs_1.default.existsSync(path_1.default.join(DIRNAME, "src", item) + ".ts");
|
|
19
|
+
if (!isExist) {
|
|
20
|
+
console.info(ansi_colors_1.default.red(`${item} not found`));
|
|
21
|
+
continue;
|
|
22
|
+
}
|
|
23
|
+
const apiItemConfig = require(path_1.default.join(DIRNAME, "src", item)).config;
|
|
24
|
+
apiConfig[item] = apiItemConfig || defaullConfig;
|
|
25
|
+
// if (!apiFunc) {
|
|
26
|
+
// console.info(c.yellow(`${item} 没有导出函数,已跳过..`));
|
|
27
|
+
// } else {
|
|
28
|
+
// apiFunc && app[Router[item].methods](item, apiFunc);
|
|
29
|
+
// }
|
|
30
|
+
}
|
|
31
|
+
state_1.state.Router = apiConfig;
|
|
32
|
+
return apiConfig;
|
|
33
|
+
}
|
|
34
|
+
exports.default = getRouterInfo;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getType = void 0;
|
|
4
|
+
function getType(obj) {
|
|
5
|
+
// "".toLocaleLowerCase
|
|
6
|
+
return Object.prototype.toString
|
|
7
|
+
.call(obj)
|
|
8
|
+
.slice(8)
|
|
9
|
+
.replace("]", "")
|
|
10
|
+
.toLocaleLowerCase();
|
|
11
|
+
}
|
|
12
|
+
exports.getType = getType;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createToken = exports.validToken = void 0;
|
|
4
|
+
const { decode, isJSON, encode } = require("./mas-encrypt.min.js");
|
|
5
|
+
const getTimestamp = () => new Date().getTime();
|
|
6
|
+
/**
|
|
7
|
+
*
|
|
8
|
+
* @param param0 token:解密的token,permission:效验的权限,只要有其中一个就可
|
|
9
|
+
* @param key 解密密钥
|
|
10
|
+
* @returns
|
|
11
|
+
*/
|
|
12
|
+
const validToken = ({ token, permission = [] }, key = "8087") => {
|
|
13
|
+
if (!token)
|
|
14
|
+
return { msg: "没有传入token数据", errorCode: 0, status: 0, token };
|
|
15
|
+
token = decode(token, key, 1);
|
|
16
|
+
if (!token)
|
|
17
|
+
return { msg: "token数据错误", errorCode: 1, status: 0, token };
|
|
18
|
+
// 鉴权
|
|
19
|
+
if (permission.length != 0) {
|
|
20
|
+
const tPermission = token._permission;
|
|
21
|
+
if (!tPermission) {
|
|
22
|
+
return { msg: "权限错误", errorCode: 2, status: 0, token };
|
|
23
|
+
}
|
|
24
|
+
if (tPermission.filter((value) => permission.includes(value)).length == 0) {
|
|
25
|
+
return { msg: "权限错误", errorCode: 2, status: 0, token };
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
// 过期时间
|
|
29
|
+
if (token._masTime !== 0) {
|
|
30
|
+
if (getTimestamp() > token._masTime)
|
|
31
|
+
return { msg: "token过期", errorCode: 3, status: 0, token };
|
|
32
|
+
}
|
|
33
|
+
return Object.assign(Object.assign({}, token), { status: 1 });
|
|
34
|
+
};
|
|
35
|
+
exports.validToken = validToken;
|
|
36
|
+
const getErrorInfo = () => {
|
|
37
|
+
return [
|
|
38
|
+
{ msg: "没有传入token数据", errorCode: 0, status: 0 },
|
|
39
|
+
{ msg: "token数据错误", errorCode: 1, status: 0 },
|
|
40
|
+
{ msg: "权限错误", errorCode: 2, status: 0 },
|
|
41
|
+
{ msg: "token过期", errorCode: 3, status: 0 },
|
|
42
|
+
];
|
|
43
|
+
};
|
|
44
|
+
/**
|
|
45
|
+
*
|
|
46
|
+
* @param param0 data:加密的数据,time:过期时间/s(为零则不会过期),permission:权限设置
|
|
47
|
+
* @param key 加密密钥
|
|
48
|
+
* @returns
|
|
49
|
+
*/
|
|
50
|
+
function createToken({ data = null, time = 0, permission = [] } = {}, key = "8087") {
|
|
51
|
+
const token = {};
|
|
52
|
+
token.data = data;
|
|
53
|
+
permission.length != 0 && (token._permission = permission);
|
|
54
|
+
time !== 0 && (token._masTime = time * 1000 + getTimestamp());
|
|
55
|
+
return encode(token, key, 1);
|
|
56
|
+
}
|
|
57
|
+
exports.createToken = createToken;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.default = (req, res, next) => {
|
|
13
|
+
// req.fields && (req.body = req.fields);
|
|
14
|
+
let right = true;
|
|
15
|
+
res.return = (data, status = 1, code = 200, msg = "") => __awaiter(void 0, void 0, void 0, function* () {
|
|
16
|
+
if (!right)
|
|
17
|
+
return;
|
|
18
|
+
right = false;
|
|
19
|
+
if (data === null || data === undefined) {
|
|
20
|
+
status = 0;
|
|
21
|
+
}
|
|
22
|
+
if (data instanceof Promise)
|
|
23
|
+
data = yield data;
|
|
24
|
+
// if (typeof data != "string") data = JSON.stringify(data);
|
|
25
|
+
res.status(code).send({
|
|
26
|
+
msg,
|
|
27
|
+
status: !!status ? 1 : 0,
|
|
28
|
+
data: data === null || data === undefined ? null : data,
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
next();
|
|
32
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
const fs = __importStar(require("fs"));
|
|
27
|
+
const path = __importStar(require("path"));
|
|
28
|
+
function readFilesRecursively(folderPath, routerPrefix = "") {
|
|
29
|
+
const files = [];
|
|
30
|
+
fs.readdirSync(folderPath).forEach((fileName) => {
|
|
31
|
+
const filePath = path.join(folderPath, fileName);
|
|
32
|
+
const stat = fs.statSync(filePath);
|
|
33
|
+
if (stat.isDirectory()) {
|
|
34
|
+
const directoryPrefix = routerPrefix
|
|
35
|
+
? `${routerPrefix}/${fileName}`
|
|
36
|
+
: fileName;
|
|
37
|
+
const directoryFiles = readFilesRecursively(filePath, directoryPrefix);
|
|
38
|
+
files.push(...directoryFiles);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
const filePrefix = routerPrefix
|
|
42
|
+
? `${routerPrefix}/${fileName}`
|
|
43
|
+
: fileName;
|
|
44
|
+
const fileRoute = `/${filePrefix.replace(/\.[^/.]+$/, "")}`;
|
|
45
|
+
files.push(fileRoute);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
return files;
|
|
49
|
+
}
|
|
50
|
+
exports.default = readFilesRecursively;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const state_1 = require("../state");
|
|
7
|
+
const validType_1 = __importDefault(require("./validType"));
|
|
8
|
+
exports.default = (req, res, next) => {
|
|
9
|
+
const Router = state_1.state.Router;
|
|
10
|
+
const routerObj = Router[req.path];
|
|
11
|
+
if (routerObj) {
|
|
12
|
+
if (routerObj.methods != "all" &&
|
|
13
|
+
routerObj.methods != req.method.toLowerCase()) {
|
|
14
|
+
return res.return("error method!", 0, 400);
|
|
15
|
+
}
|
|
16
|
+
if (routerObj.header && routerObj.header.length != 0) {
|
|
17
|
+
const headerObj = {};
|
|
18
|
+
routerObj.header.forEach((item) => {
|
|
19
|
+
!item.optional && (headerObj[item.name] = item.type);
|
|
20
|
+
});
|
|
21
|
+
if (!(0, validType_1.default)(req.headers, headerObj)) {
|
|
22
|
+
return res.return("error headers format!", 0, 400);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
if (req.method == "GET" &&
|
|
26
|
+
routerObj.validFormat &&
|
|
27
|
+
!(0, validType_1.default)(req.query, routerObj.validFormat, !!routerObj.validFormatStrict)) {
|
|
28
|
+
return res.return("error data format!", 0, 400);
|
|
29
|
+
}
|
|
30
|
+
if (req.method == "POST" &&
|
|
31
|
+
routerObj.validFormat &&
|
|
32
|
+
!(0, validType_1.default)(req.body, routerObj.validFormat, !!routerObj.validFormatStrict)) {
|
|
33
|
+
return res.return("error data format!", 0, 400);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
next();
|
|
37
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const state_1 = require("../state");
|
|
4
|
+
const __1 = require("..");
|
|
5
|
+
const masUtils_1 = require("./masUtils");
|
|
6
|
+
exports.default = (req, res, next) => {
|
|
7
|
+
const r = state_1.state.Router[req.path];
|
|
8
|
+
const tokenConfig = state_1.state.config.token;
|
|
9
|
+
if ((0, masUtils_1.getType)(r === null || r === void 0 ? void 0 : r.permission) == "array") {
|
|
10
|
+
const token = req.headers[tokenConfig.headerParams];
|
|
11
|
+
if (!token) {
|
|
12
|
+
return res.return("缺少重要参数", 0, 400);
|
|
13
|
+
}
|
|
14
|
+
let vt = (0, __1.validToken)({ token, permission: r.permission }, tokenConfig.pwd);
|
|
15
|
+
if (vt.status === 0) {
|
|
16
|
+
return res.return(vt.msg, 0, 200, vt.errorCode);
|
|
17
|
+
}
|
|
18
|
+
res.token = vt;
|
|
19
|
+
next();
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
next();
|
|
23
|
+
}
|
|
24
|
+
};
|