midway-fatcms 0.0.1-beta.29 → 0.0.1-beta.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.json +14 -14
- package/.prettierrc.js +4 -4
- package/README.md +8 -8
- package/index.d.ts +10 -10
- package/package.json +76 -76
- package/tsconfig.json +32 -32
- package/dist/config/config.default.d.ts +0 -3
- package/dist/config/config.default.js +0 -189
- package/dist/config/seed/aeskey.txt +0 -1
- package/dist/config/utils.d.ts +0 -1
- package/dist/config/utils.js +0 -23
- package/dist/configuration.d.ts +0 -7
- package/dist/configuration.js +0 -113
- package/dist/controller/base/BaseApiController.d.ts +0 -37
- package/dist/controller/base/BaseApiController.js +0 -164
- package/dist/controller/gateway/AnyApiGatewayController.d.ts +0 -13
- package/dist/controller/gateway/AnyApiGatewayController.js +0 -55
- package/dist/controller/gateway/AsyncTaskController.d.ts +0 -20
- package/dist/controller/gateway/AsyncTaskController.js +0 -181
- package/dist/controller/gateway/CrudMtdGatewayController.d.ts +0 -21
- package/dist/controller/gateway/CrudMtdGatewayController.js +0 -119
- package/dist/controller/gateway/CrudStdGatewayController.d.ts +0 -38
- package/dist/controller/gateway/CrudStdGatewayController.js +0 -137
- package/dist/controller/gateway/DocGatewayController.d.ts +0 -27
- package/dist/controller/gateway/DocGatewayController.js +0 -179
- package/dist/controller/gateway/FileController.d.ts +0 -25
- package/dist/controller/gateway/FileController.js +0 -129
- package/dist/controller/gateway/ProxyApiGatewayController.d.ts +0 -18
- package/dist/controller/gateway/ProxyApiGatewayController.js +0 -78
- package/dist/controller/gateway/PublicApiController.d.ts +0 -27
- package/dist/controller/gateway/PublicApiController.js +0 -165
- package/dist/controller/gateway/StaticController.d.ts +0 -24
- package/dist/controller/gateway/StaticController.js +0 -288
- package/dist/controller/helpers.controller.d.ts +0 -39
- package/dist/controller/helpers.controller.js +0 -188
- package/dist/controller/home.controller.d.ts +0 -9
- package/dist/controller/home.controller.js +0 -72
- package/dist/controller/manage/AnyApiMangeApi.d.ts +0 -10
- package/dist/controller/manage/AnyApiMangeApi.js +0 -98
- package/dist/controller/manage/AppLogMangeApi.d.ts +0 -10
- package/dist/controller/manage/AppLogMangeApi.js +0 -88
- package/dist/controller/manage/AppMangeApi.d.ts +0 -10
- package/dist/controller/manage/AppMangeApi.js +0 -88
- package/dist/controller/manage/AppPageMangeApi.d.ts +0 -10
- package/dist/controller/manage/AppPageMangeApi.js +0 -87
- package/dist/controller/manage/AppSchemaHistoryApi.d.ts +0 -10
- package/dist/controller/manage/AppSchemaHistoryApi.js +0 -83
- package/dist/controller/manage/CrudMethodsMangeApi.d.ts +0 -10
- package/dist/controller/manage/CrudMethodsMangeApi.js +0 -84
- package/dist/controller/manage/CrudStandardDesignApi.d.ts +0 -38
- package/dist/controller/manage/CrudStandardDesignApi.js +0 -342
- package/dist/controller/manage/DataDictManageApi.d.ts +0 -15
- package/dist/controller/manage/DataDictManageApi.js +0 -133
- package/dist/controller/manage/DeployManageApi.d.ts +0 -19
- package/dist/controller/manage/DeployManageApi.js +0 -180
- package/dist/controller/manage/DocLibManageApi.d.ts +0 -10
- package/dist/controller/manage/DocLibManageApi.js +0 -104
- package/dist/controller/manage/DocManageApi.d.ts +0 -11
- package/dist/controller/manage/DocManageApi.js +0 -130
- package/dist/controller/manage/FileManageApi.d.ts +0 -13
- package/dist/controller/manage/FileManageApi.js +0 -77
- package/dist/controller/manage/LowCodeTplManageApi.d.ts +0 -13
- package/dist/controller/manage/LowCodeTplManageApi.js +0 -86
- package/dist/controller/manage/MenuManageApi.d.ts +0 -10
- package/dist/controller/manage/MenuManageApi.js +0 -93
- package/dist/controller/manage/ProxyApiMangeApi.d.ts +0 -10
- package/dist/controller/manage/ProxyApiMangeApi.js +0 -87
- package/dist/controller/manage/SuperAdminManageApi.d.ts +0 -24
- package/dist/controller/manage/SuperAdminManageApi.js +0 -153
- package/dist/controller/manage/SysConfigMangeApi.d.ts +0 -11
- package/dist/controller/manage/SysConfigMangeApi.js +0 -126
- package/dist/controller/manage/SystemInfoManageApi.d.ts +0 -12
- package/dist/controller/manage/SystemInfoManageApi.js +0 -72
- package/dist/controller/manage/UserAccountManageApi.d.ts +0 -14
- package/dist/controller/manage/UserAccountManageApi.js +0 -129
- package/dist/controller/manage/WorkbenchMangeApi.d.ts +0 -11
- package/dist/controller/manage/WorkbenchMangeApi.js +0 -103
- package/dist/controller/myinfo/AuthController.d.ts +0 -33
- package/dist/controller/myinfo/AuthController.js +0 -136
- package/dist/controller/myinfo/MyInfoController.d.ts +0 -13
- package/dist/controller/myinfo/MyInfoController.js +0 -51
- package/dist/controller/render/AppRenderController.d.ts +0 -11
- package/dist/controller/render/AppRenderController.js +0 -92
- package/dist/controller/test.controller.d.ts +0 -8
- package/dist/controller/test.controller.js +0 -51
- package/dist/filter/default.filter.d.ts +0 -7
- package/dist/filter/default.filter.js +0 -23
- package/dist/filter/notfound.filter.d.ts +0 -5
- package/dist/filter/notfound.filter.js +0 -20
- package/dist/index.d.ts +0 -102
- package/dist/index.js +0 -120
- package/dist/interface.d.ts +0 -27
- package/dist/interface.js +0 -3
- package/dist/libs/crud-pro/CrudPro.d.ts +0 -37
- package/dist/libs/crud-pro/CrudPro.js +0 -136
- package/dist/libs/crud-pro/defaultConfigs.d.ts +0 -4
- package/dist/libs/crud-pro/defaultConfigs.js +0 -15
- package/dist/libs/crud-pro/exceptions.d.ts +0 -104
- package/dist/libs/crud-pro/exceptions.js +0 -117
- package/dist/libs/crud-pro/interfaces.d.ts +0 -163
- package/dist/libs/crud-pro/interfaces.js +0 -12
- package/dist/libs/crud-pro/models/ExecuteContext.d.ts +0 -49
- package/dist/libs/crud-pro/models/ExecuteContext.js +0 -79
- package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +0 -38
- package/dist/libs/crud-pro/models/ExecuteContextFunc.js +0 -72
- package/dist/libs/crud-pro/models/FuncContext.d.ts +0 -18
- package/dist/libs/crud-pro/models/FuncContext.js +0 -6
- package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +0 -65
- package/dist/libs/crud-pro/models/RequestCfgModel.js +0 -81
- package/dist/libs/crud-pro/models/RequestModel.d.ts +0 -25
- package/dist/libs/crud-pro/models/RequestModel.js +0 -113
- package/dist/libs/crud-pro/models/ResModel.d.ts +0 -16
- package/dist/libs/crud-pro/models/ResModel.js +0 -2
- package/dist/libs/crud-pro/models/ServiceHub.d.ts +0 -20
- package/dist/libs/crud-pro/models/ServiceHub.js +0 -2
- package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +0 -22
- package/dist/libs/crud-pro/models/SqlCfgModel.js +0 -40
- package/dist/libs/crud-pro/models/SqlSegArg.d.ts +0 -6
- package/dist/libs/crud-pro/models/SqlSegArg.js +0 -12
- package/dist/libs/crud-pro/models/Transaction.d.ts +0 -29
- package/dist/libs/crud-pro/models/Transaction.js +0 -67
- package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +0 -28
- package/dist/libs/crud-pro/models/TransactionMySQL.js +0 -76
- package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +0 -28
- package/dist/libs/crud-pro/models/TransactionPostgres.js +0 -85
- package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +0 -34
- package/dist/libs/crud-pro/models/TransactionSqlServer.js +0 -92
- package/dist/libs/crud-pro/models/keys.d.ts +0 -106
- package/dist/libs/crud-pro/models/keys.js +0 -149
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +0 -11
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +0 -73
- package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +0 -9
- package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +0 -112
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +0 -17
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +0 -225
- package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +0 -9
- package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +0 -51
- package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +0 -13
- package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +0 -148
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +0 -24
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +0 -340
- package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +0 -25
- package/dist/libs/crud-pro/services/CrudProGenSqlService.js +0 -165
- package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +0 -32
- package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +0 -334
- package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +0 -24
- package/dist/libs/crud-pro/services/CrudProServiceBase.js +0 -79
- package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +0 -9
- package/dist/libs/crud-pro/services/CrudProTableMetaService.js +0 -78
- package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +0 -32
- package/dist/libs/crud-pro/services/CurdProServiceHub.js +0 -64
- package/dist/libs/crud-pro/sql.txt +0 -120
- package/dist/libs/crud-pro/utils/CompareUtils.d.ts +0 -9
- package/dist/libs/crud-pro/utils/CompareUtils.js +0 -25
- package/dist/libs/crud-pro/utils/DatabaseName.d.ts +0 -9
- package/dist/libs/crud-pro/utils/DatabaseName.js +0 -50
- package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +0 -7
- package/dist/libs/crud-pro/utils/DateTimeUtils.js +0 -21
- package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +0 -19
- package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +0 -47
- package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +0 -5
- package/dist/libs/crud-pro/utils/MessageParseUtils.js +0 -33
- package/dist/libs/crud-pro/utils/MixinUtils.d.ts +0 -39
- package/dist/libs/crud-pro/utils/MixinUtils.js +0 -255
- package/dist/libs/crud-pro/utils/ModelUtils.d.ts +0 -11
- package/dist/libs/crud-pro/utils/ModelUtils.js +0 -49
- package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +0 -11
- package/dist/libs/crud-pro/utils/MultiKeyMap.js +0 -63
- package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +0 -5
- package/dist/libs/crud-pro/utils/SqlFuncUtils.js +0 -29
- package/dist/libs/crud-pro/utils/TypeUtils.d.ts +0 -40
- package/dist/libs/crud-pro/utils/TypeUtils.js +0 -166
- package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +0 -3
- package/dist/libs/crud-pro/utils/ValidateUtils.js +0 -165
- package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +0 -3
- package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +0 -19
- package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +0 -3
- package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +0 -20
- package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +0 -3
- package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +0 -20
- package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +0 -4
- package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +0 -21
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +0 -3
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +0 -22
- package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +0 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +0 -11
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +0 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +0 -11
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +0 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +0 -128
- package/dist/libs/global-config/global-config.d.ts +0 -45
- package/dist/libs/global-config/global-config.js +0 -33
- package/dist/libs/utils/common-dto.d.ts +0 -18
- package/dist/libs/utils/common-dto.js +0 -40
- package/dist/libs/utils/crypto-utils.d.ts +0 -3
- package/dist/libs/utils/crypto-utils.js +0 -46
- package/dist/libs/utils/errorToString.d.ts +0 -2
- package/dist/libs/utils/errorToString.js +0 -57
- package/dist/libs/utils/fatcms-request.d.ts +0 -30
- package/dist/libs/utils/fatcms-request.js +0 -104
- package/dist/libs/utils/functions.d.ts +0 -5
- package/dist/libs/utils/functions.js +0 -68
- package/dist/libs/utils/ordernum-utils.d.ts +0 -2
- package/dist/libs/utils/ordernum-utils.js +0 -13
- package/dist/libs/utils/parseConfig.d.ts +0 -7
- package/dist/libs/utils/parseConfig.js +0 -44
- package/dist/libs/utils/parseCreateSql.d.ts +0 -5
- package/dist/libs/utils/parseCreateSql.js +0 -86
- package/dist/libs/utils/render-utils.d.ts +0 -28
- package/dist/libs/utils/render-utils.js +0 -135
- package/dist/middleware/forbidden.middleware.d.ts +0 -10
- package/dist/middleware/forbidden.middleware.js +0 -54
- package/dist/middleware/global.middleware.d.ts +0 -10
- package/dist/middleware/global.middleware.js +0 -266
- package/dist/middleware/permission.middleware.d.ts +0 -18
- package/dist/middleware/permission.middleware.js +0 -74
- package/dist/middleware/tx.middleware.d.ts +0 -9
- package/dist/middleware/tx.middleware.js +0 -40
- package/dist/models/AsyncTaskModel.d.ts +0 -74
- package/dist/models/AsyncTaskModel.js +0 -31
- package/dist/models/RedisKeys.d.ts +0 -14
- package/dist/models/RedisKeys.js +0 -17
- package/dist/models/SystemEntities.d.ts +0 -98
- package/dist/models/SystemEntities.js +0 -2
- package/dist/models/SystemPerm.d.ts +0 -95
- package/dist/models/SystemPerm.js +0 -100
- package/dist/models/SystemTables.d.ts +0 -25
- package/dist/models/SystemTables.js +0 -28
- package/dist/models/bizmodels.d.ts +0 -97
- package/dist/models/bizmodels.js +0 -39
- package/dist/models/contextLogger.d.ts +0 -25
- package/dist/models/contextLogger.js +0 -112
- package/dist/models/devops.d.ts +0 -12
- package/dist/models/devops.js +0 -19
- package/dist/models/userSession.d.ts +0 -61
- package/dist/models/userSession.js +0 -165
- package/dist/schedule/anonymousContext.d.ts +0 -14
- package/dist/schedule/anonymousContext.js +0 -59
- package/dist/schedule/index.d.ts +0 -4
- package/dist/schedule/index.js +0 -10
- package/dist/schedule/runSchedule.d.ts +0 -12
- package/dist/schedule/runSchedule.js +0 -68
- package/dist/schedule/scheduleNames.d.ts +0 -13
- package/dist/schedule/scheduleNames.js +0 -17
- package/dist/service/AuthService.d.ts +0 -70
- package/dist/service/AuthService.js +0 -251
- package/dist/service/EnumInfoService.d.ts +0 -30
- package/dist/service/EnumInfoService.js +0 -127
- package/dist/service/FileCenterService.d.ts +0 -43
- package/dist/service/FileCenterService.js +0 -351
- package/dist/service/SysConfigService.d.ts +0 -7
- package/dist/service/SysConfigService.js +0 -47
- package/dist/service/UserAccountService.d.ts +0 -23
- package/dist/service/UserAccountService.js +0 -107
- package/dist/service/UserSessionService.d.ts +0 -37
- package/dist/service/UserSessionService.js +0 -156
- package/dist/service/VisitStatService.d.ts +0 -14
- package/dist/service/VisitStatService.js +0 -158
- package/dist/service/WorkbenchService.d.ts +0 -52
- package/dist/service/WorkbenchService.js +0 -202
- package/dist/service/anyapi/AnyApiSandboxService.d.ts +0 -15
- package/dist/service/anyapi/AnyApiSandboxService.js +0 -122
- package/dist/service/anyapi/AnyApiService.d.ts +0 -27
- package/dist/service/anyapi/AnyApiService.js +0 -181
- package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +0 -50
- package/dist/service/asyncTask/AsyncTaskRunnerService.js +0 -287
- package/dist/service/asyncTask/AsyncTaskService.d.ts +0 -7
- package/dist/service/asyncTask/AsyncTaskService.js +0 -34
- package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +0 -10
- package/dist/service/asyncTask/handler/ExcelInfoModel.js +0 -2
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +0 -7
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +0 -216
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +0 -36
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +0 -139
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +0 -46
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +0 -121
- package/dist/service/base/ApiBaseService.d.ts +0 -15
- package/dist/service/base/ApiBaseService.js +0 -50
- package/dist/service/base/ApiRateLimiter.d.ts +0 -10
- package/dist/service/base/ApiRateLimiter.js +0 -51
- package/dist/service/base/BaseService.d.ts +0 -41
- package/dist/service/base/BaseService.js +0 -101
- package/dist/service/base/RedisCacheService.d.ts +0 -20
- package/dist/service/base/RedisCacheService.js +0 -57
- package/dist/service/crudstd/CrudStdActionService.d.ts +0 -17
- package/dist/service/crudstd/CrudStdActionService.js +0 -32
- package/dist/service/crudstd/CrudStdConstant.d.ts +0 -58
- package/dist/service/crudstd/CrudStdConstant.js +0 -64
- package/dist/service/crudstd/CrudStdRelationService.d.ts +0 -10
- package/dist/service/crudstd/CrudStdRelationService.js +0 -85
- package/dist/service/crudstd/CrudStdService.d.ts +0 -57
- package/dist/service/crudstd/CrudStdService.js +0 -239
- package/dist/service/curd/CrudProQuick.d.ts +0 -24
- package/dist/service/curd/CrudProQuick.js +0 -109
- package/dist/service/curd/CurdMixByAccountService.d.ts +0 -9
- package/dist/service/curd/CurdMixByAccountService.js +0 -93
- package/dist/service/curd/CurdMixByDictService.d.ts +0 -13
- package/dist/service/curd/CurdMixByDictService.js +0 -114
- package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +0 -31
- package/dist/service/curd/CurdMixByLinkToCustomService.js +0 -203
- package/dist/service/curd/CurdMixBySysConfigService.d.ts +0 -9
- package/dist/service/curd/CurdMixBySysConfigService.js +0 -80
- package/dist/service/curd/CurdMixByWorkbenchService.d.ts +0 -10
- package/dist/service/curd/CurdMixByWorkbenchService.js +0 -78
- package/dist/service/curd/CurdMixService.d.ts +0 -27
- package/dist/service/curd/CurdMixService.js +0 -100
- package/dist/service/curd/CurdMixUtils.d.ts +0 -51
- package/dist/service/curd/CurdMixUtils.js +0 -275
- package/dist/service/curd/CurdProService.d.ts +0 -32
- package/dist/service/curd/CurdProService.js +0 -210
- package/dist/service/curd/fixCfgModel.d.ts +0 -3
- package/dist/service/curd/fixCfgModel.js +0 -107
- package/dist/service/proxyapi/ProxyApiLoadService.d.ts +0 -21
- package/dist/service/proxyapi/ProxyApiLoadService.js +0 -167
- package/dist/service/proxyapi/ProxyApiService.d.ts +0 -60
- package/dist/service/proxyapi/ProxyApiService.js +0 -260
- package/dist/service/proxyapi/ProxyApiUtils.d.ts +0 -15
- package/dist/service/proxyapi/ProxyApiUtils.js +0 -34
- package/dist/service/proxyapi/RouteHandler.d.ts +0 -5
- package/dist/service/proxyapi/RouteHandler.js +0 -9
- package/dist/service/proxyapi/RouteTrie.d.ts +0 -12
- package/dist/service/proxyapi/RouteTrie.js +0 -63
- package/dist/service/proxyapi/WeightedRandom.d.ts +0 -9
- package/dist/service/proxyapi/WeightedRandom.js +0 -31
- package/dist/service/proxyapi/WeightedRoundRobin.d.ts +0 -8
- package/dist/service/proxyapi/WeightedRoundRobin.js +0 -32
- package/dist/views/404_app.html +0 -31
- package/dist/views/404_workbench.html +0 -34
- package/dist/views/static/favicon.ico +0 -0
|
@@ -1,275 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.RelatedType = exports.CrudMixUtils = void 0;
|
|
4
|
-
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
5
|
-
const MixinUtils_1 = require("../../libs/crud-pro/utils/MixinUtils");
|
|
6
|
-
const _ = require("lodash");
|
|
7
|
-
const functions_1 = require("../../libs/utils/functions");
|
|
8
|
-
var RelatedType;
|
|
9
|
-
(function (RelatedType) {
|
|
10
|
-
RelatedType["dict"] = "dict";
|
|
11
|
-
RelatedType["sysCfgEnum"] = "sysCfgEnum";
|
|
12
|
-
RelatedType["linkToCustom"] = "linkToCustom";
|
|
13
|
-
RelatedType["accountBasic"] = "accountBasic";
|
|
14
|
-
RelatedType["workbenchBasic"] = "workbenchBasic";
|
|
15
|
-
})(RelatedType || (RelatedType = {}));
|
|
16
|
-
exports.RelatedType = RelatedType;
|
|
17
|
-
const { isNotEmpty } = MixinUtils_1.MixinUtils;
|
|
18
|
-
function getColumnsRelationAll(sqlCfg, cfgModel) {
|
|
19
|
-
if (sqlCfg && Array.isArray(sqlCfg.columnsRelation) && sqlCfg.columnsRelation.length > 0) {
|
|
20
|
-
return sqlCfg.columnsRelation;
|
|
21
|
-
}
|
|
22
|
-
if (cfgModel && Array.isArray(cfgModel.columnsRelation) && cfgModel.columnsRelation.length > 0) {
|
|
23
|
-
return cfgModel.columnsRelation;
|
|
24
|
-
}
|
|
25
|
-
return [];
|
|
26
|
-
}
|
|
27
|
-
const forEachColumnsRelation = (row, columnsRelation, func) => {
|
|
28
|
-
for (let i = 0; i < columnsRelation.length; i++) {
|
|
29
|
-
func(row, columnsRelation[i]);
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
function copyBySingleSourceValue(row, sourceValue, targetColumns, getValue) {
|
|
33
|
-
// const codeObject = map.get(sourceValue);
|
|
34
|
-
const codeObject = getValue(sourceValue);
|
|
35
|
-
if (typeof codeObject === 'undefined' || codeObject === null) {
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
if (Array.isArray(targetColumns)) {
|
|
39
|
-
for (let i = 0; i < targetColumns.length; i++) {
|
|
40
|
-
const targetColumn = targetColumns[i];
|
|
41
|
-
const toStr = targetColumn.to.replace('[$ARRAY_INDEX]', '');
|
|
42
|
-
if (targetColumn.from === '*') {
|
|
43
|
-
_.set(row, toStr, codeObject);
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
const dictAttrValue = _.get(codeObject, targetColumn.from);
|
|
47
|
-
if (typeof dictAttrValue !== 'undefined' && dictAttrValue !== null) {
|
|
48
|
-
_.set(row, toStr, dictAttrValue);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
function copyByArraySourceValueInner(row, codes, targetColumns, getValue, resultObj) {
|
|
55
|
-
for (let codeIndex = 0; codeIndex < codes.length; codeIndex++) {
|
|
56
|
-
const code = codes[codeIndex];
|
|
57
|
-
// const codeObject = map.get(code);
|
|
58
|
-
const codeObject = getValue(code);
|
|
59
|
-
if (codeObject) {
|
|
60
|
-
if (Array.isArray(targetColumns)) {
|
|
61
|
-
for (let i = 0; i < targetColumns.length; i++) {
|
|
62
|
-
const targetColumn = targetColumns[i];
|
|
63
|
-
if (targetColumn.from === '*') {
|
|
64
|
-
const toStr = targetColumn.to.replace('$ARRAY_INDEX', `${codeIndex}`);
|
|
65
|
-
_.set(row, toStr, codeObject);
|
|
66
|
-
resultObj.isSetArray = true;
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
const dictAttrValue = _.get(codeObject, targetColumn.from);
|
|
70
|
-
if (typeof dictAttrValue !== 'undefined' && dictAttrValue !== null) {
|
|
71
|
-
const toStr = targetColumn.to.replace('$ARRAY_INDEX', `${codeIndex}`);
|
|
72
|
-
_.set(row, toStr, dictAttrValue);
|
|
73
|
-
resultObj.isSetArray = true;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
function copyByArraySourceValue(row, sourceValue, targetColumns, getValue) {
|
|
82
|
-
const resultObj = { isSetArray: false };
|
|
83
|
-
// 支持关联JSON数组。使用 字符串存储的类型
|
|
84
|
-
if (typeof sourceValue === 'string' && sourceValue.startsWith('[') && sourceValue.endsWith(']')) {
|
|
85
|
-
const codes = (0, functions_1.parseJsonObject)(sourceValue);
|
|
86
|
-
if (Array.isArray(codes)) {
|
|
87
|
-
copyByArraySourceValueInner(row, codes, targetColumns, getValue, resultObj);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
else if (Array.isArray(sourceValue)) {
|
|
91
|
-
// 直接使用JSON或者postgres的数组存储的类型
|
|
92
|
-
copyByArraySourceValueInner(row, sourceValue, targetColumns, getValue, resultObj);
|
|
93
|
-
}
|
|
94
|
-
return resultObj.isSetArray;
|
|
95
|
-
}
|
|
96
|
-
class CrudMixUtils {
|
|
97
|
-
constructor(relatedType) {
|
|
98
|
-
this.relatedType = relatedType;
|
|
99
|
-
}
|
|
100
|
-
getColumnsRelation(sqlCfg, cfgModel) {
|
|
101
|
-
const ss = getColumnsRelationAll(sqlCfg, cfgModel);
|
|
102
|
-
const relatedType = this.relatedType;
|
|
103
|
-
return ss.filter(s => s.relatedType === relatedType);
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* 从执行上下文,获取所有的关联关系
|
|
107
|
-
* @param exeCtxType
|
|
108
|
-
* @returns
|
|
109
|
-
*/
|
|
110
|
-
pickColumnRelations(exeCtxType) {
|
|
111
|
-
// 自定义的关联关系
|
|
112
|
-
const customExeCtx = exeCtxType;
|
|
113
|
-
if (customExeCtx.isCustomContext) {
|
|
114
|
-
const customExeCtx = exeCtxType;
|
|
115
|
-
return customExeCtx.columnsRelation;
|
|
116
|
-
}
|
|
117
|
-
// 默认的执行上下文
|
|
118
|
-
const relationResult = [];
|
|
119
|
-
const exeCtx = exeCtxType;
|
|
120
|
-
const cfgModel = exeCtx.getCfgModel();
|
|
121
|
-
const sqlModels = exeCtx.getSqlCfgModels();
|
|
122
|
-
if (Array.isArray(sqlModels) && sqlModels.length > 0) {
|
|
123
|
-
for (let i = 0; i < sqlModels.length; i++) {
|
|
124
|
-
const sqlModel = sqlModels[i];
|
|
125
|
-
// 只有Select语句需要
|
|
126
|
-
if (sqlModel && sqlModel.getCrudType() === keys_1.KeyOfCrudTypes.SELECT) {
|
|
127
|
-
const columnsRelation = this.getColumnsRelation(sqlModel, cfgModel);
|
|
128
|
-
for (let j = 0; j < columnsRelation.length; j++) {
|
|
129
|
-
const relation = columnsRelation[j];
|
|
130
|
-
if (relation.relatedType === this.relatedType) {
|
|
131
|
-
relationResult.push(relation);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
return _.uniqBy(relationResult, (obj) => {
|
|
138
|
-
return `${obj.relatedCode}_${obj.relatedType}_${obj.sourceColumn}_${JSON.stringify(obj.targetColumns)}`;
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
/**
|
|
142
|
-
* 从执行上下文,获取所有的关联关系的代码
|
|
143
|
-
* @param exeCtx
|
|
144
|
-
* @returns
|
|
145
|
-
*/
|
|
146
|
-
pickColumnRelationCodes(exeCtx) {
|
|
147
|
-
const relationResult = this.pickColumnRelations(exeCtx);
|
|
148
|
-
const codes = relationResult.map(e => e.relatedCode);
|
|
149
|
-
if (!codes || codes.length === 0) {
|
|
150
|
-
return [];
|
|
151
|
-
}
|
|
152
|
-
return [...new Set(codes)]; // 去重
|
|
153
|
-
}
|
|
154
|
-
/**
|
|
155
|
-
* 遍历每一行,每一个关联列
|
|
156
|
-
* @param exeCtxType
|
|
157
|
-
* @param func
|
|
158
|
-
* @returns
|
|
159
|
-
*/
|
|
160
|
-
forEachRowAndColumnsRelation(exeCtxType, func) {
|
|
161
|
-
// 自定义的关联关系
|
|
162
|
-
const customExeCtx = exeCtxType;
|
|
163
|
-
if (customExeCtx.isCustomContext) {
|
|
164
|
-
const rows = customExeCtx.rows || [];
|
|
165
|
-
const columnsRelation = customExeCtx.columnsRelation;
|
|
166
|
-
for (let index = 0; index < rows.length; index++) {
|
|
167
|
-
const row = rows[index];
|
|
168
|
-
forEachColumnsRelation(row, columnsRelation, func);
|
|
169
|
-
}
|
|
170
|
-
return;
|
|
171
|
-
}
|
|
172
|
-
// 默认的执行上下文
|
|
173
|
-
const exeCtx = exeCtxType;
|
|
174
|
-
const sqlCfgList = exeCtx.getSqlCfgModels();
|
|
175
|
-
const resModel = exeCtx.getResModel();
|
|
176
|
-
const cfgModel = exeCtx.getCfgModel();
|
|
177
|
-
for (let i = 0; i < sqlCfgList.length; i++) {
|
|
178
|
-
const sqlCfg = sqlCfgList[i];
|
|
179
|
-
// 只有Select语句需要
|
|
180
|
-
if (sqlCfg && sqlCfg.getCrudType() === keys_1.KeyOfCrudTypes.SELECT) {
|
|
181
|
-
const columnsRelation = this.getColumnsRelation(sqlCfg, cfgModel);
|
|
182
|
-
if (isNotEmpty(columnsRelation)) {
|
|
183
|
-
const resValue = resModel[sqlCfg.resName];
|
|
184
|
-
if (Array.isArray(resValue) && isNotEmpty(resValue)) {
|
|
185
|
-
// 多行查询时
|
|
186
|
-
for (const row of resValue) {
|
|
187
|
-
forEachColumnsRelation(row, columnsRelation, func);
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
else if (typeof resValue === 'object' && isNotEmpty(resValue)) {
|
|
191
|
-
// 单行查询时
|
|
192
|
-
forEachColumnsRelation(resValue, columnsRelation, func);
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
copyColumnRelationToRow(row, multiKeyMap, columnRelation) {
|
|
199
|
-
const { relatedCode, sourceColumn, targetColumns } = columnRelation;
|
|
200
|
-
if (!sourceColumn || !targetColumns) {
|
|
201
|
-
return;
|
|
202
|
-
}
|
|
203
|
-
const sourceValue = _.get(row, sourceColumn);
|
|
204
|
-
if (typeof sourceValue === 'undefined' || sourceValue === null) {
|
|
205
|
-
return;
|
|
206
|
-
}
|
|
207
|
-
const getValue = (code) => {
|
|
208
|
-
return multiKeyMap.getValue(relatedCode, code);
|
|
209
|
-
};
|
|
210
|
-
const isSetArray = copyByArraySourceValue(row, sourceValue, targetColumns, getValue);
|
|
211
|
-
if (!isSetArray) {
|
|
212
|
-
copyBySingleSourceValue(row, sourceValue, targetColumns, getValue);
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
/**
|
|
216
|
-
* 无relatedCode模式
|
|
217
|
-
* @param row
|
|
218
|
-
* @param map
|
|
219
|
-
* @param columnRelation
|
|
220
|
-
*/
|
|
221
|
-
copyColumnRelationToRowNoRelatedCode(row, map, columnRelation) {
|
|
222
|
-
const { sourceColumn, targetColumns } = columnRelation;
|
|
223
|
-
if (!sourceColumn || !targetColumns) {
|
|
224
|
-
return;
|
|
225
|
-
}
|
|
226
|
-
const sourceValue = _.get(row, sourceColumn);
|
|
227
|
-
if (!sourceValue) {
|
|
228
|
-
return;
|
|
229
|
-
}
|
|
230
|
-
const getValue = (code) => {
|
|
231
|
-
if (!map) {
|
|
232
|
-
return null;
|
|
233
|
-
}
|
|
234
|
-
if (typeof map.get === 'function') {
|
|
235
|
-
return map.get(`${code}`);
|
|
236
|
-
}
|
|
237
|
-
return map[code];
|
|
238
|
-
};
|
|
239
|
-
const isSetArray = copyByArraySourceValue(row, sourceValue, targetColumns, getValue);
|
|
240
|
-
if (!isSetArray) {
|
|
241
|
-
copyBySingleSourceValue(row, sourceValue, targetColumns, getValue);
|
|
242
|
-
}
|
|
243
|
-
}
|
|
244
|
-
/**
|
|
245
|
-
* 专门COPY用户信息到row上面。无relatedCode模式
|
|
246
|
-
* @param row
|
|
247
|
-
* @param map
|
|
248
|
-
* @param columnRelation
|
|
249
|
-
*/
|
|
250
|
-
copyUserInfoToRowNoRelatedCode(row, map, columnRelation) {
|
|
251
|
-
const { targetColumns } = columnRelation;
|
|
252
|
-
if (!targetColumns) {
|
|
253
|
-
return;
|
|
254
|
-
}
|
|
255
|
-
const tmpSourceColumn = '__fatcmsUserAccountId__';
|
|
256
|
-
const sourceValue = _.get(row, tmpSourceColumn);
|
|
257
|
-
if (!sourceValue) {
|
|
258
|
-
return;
|
|
259
|
-
}
|
|
260
|
-
const getValue = (code) => {
|
|
261
|
-
if (!map) {
|
|
262
|
-
return null;
|
|
263
|
-
}
|
|
264
|
-
if (typeof map.get === 'function') {
|
|
265
|
-
return map.get(`${code}`);
|
|
266
|
-
}
|
|
267
|
-
return map[code];
|
|
268
|
-
};
|
|
269
|
-
const isSetArray = copyByArraySourceValue(row, sourceValue, targetColumns, getValue);
|
|
270
|
-
if (!isSetArray) {
|
|
271
|
-
copyBySingleSourceValue(row, sourceValue, targetColumns, getValue);
|
|
272
|
-
}
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
exports.CrudMixUtils = CrudMixUtils;
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { Context } from '@midwayjs/koa';
|
|
2
|
-
import { IRequestCfgModel, IRequestModel, ISqlCfgModel } from '../../libs/crud-pro/interfaces';
|
|
3
|
-
import { SqlDbType } from '../../libs/crud-pro/models/keys';
|
|
4
|
-
import { ExecuteContext, IExecuteContextHandler } from '../../libs/crud-pro/models/ExecuteContext';
|
|
5
|
-
import { RelatedType } from './CurdMixUtils';
|
|
6
|
-
import { BaseService } from '../base/BaseService';
|
|
7
|
-
import { IRequestCfgModel2 } from '../../models/bizmodels';
|
|
8
|
-
import { CrudProQuick } from '../../service/curd/CrudProQuick';
|
|
9
|
-
export declare class CurdProService extends BaseService {
|
|
10
|
-
protected ctx: Context;
|
|
11
|
-
private mysql2Config;
|
|
12
|
-
private postgres2Config;
|
|
13
|
-
private sqlserver2Config;
|
|
14
|
-
private crudProCfg;
|
|
15
|
-
private responseCfgHandlers;
|
|
16
|
-
setResponseCfgHandlers(key: RelatedType, handler: IExecuteContextHandler): void;
|
|
17
|
-
getResponseCfgHandlers(): Record<RelatedType, IExecuteContextHandler>;
|
|
18
|
-
/**
|
|
19
|
-
* Execute级别:每次调用都会产生新的
|
|
20
|
-
* @private
|
|
21
|
-
*/
|
|
22
|
-
private getCrudPro;
|
|
23
|
-
/**
|
|
24
|
-
* 依赖缓存中与加载的配置
|
|
25
|
-
* @param reqJson
|
|
26
|
-
*/
|
|
27
|
-
executeCrud(reqJson: IRequestModel): Promise<ExecuteContext>;
|
|
28
|
-
executeSQL(sqlCfgModel: ISqlCfgModel): Promise<any>;
|
|
29
|
-
executeCrudByCfg(reqJson: IRequestModel, cfgModel: IRequestCfgModel2): Promise<ExecuteContext>;
|
|
30
|
-
getBbUtil(sqlDatabase: string, sqlDbType: SqlDbType, sqlTable?: string): CrudProQuick;
|
|
31
|
-
getCachedCfgByMethod(method: string): Promise<IRequestCfgModel>;
|
|
32
|
-
}
|
|
@@ -1,210 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.CurdProService = void 0;
|
|
13
|
-
const _ = require("lodash");
|
|
14
|
-
const core_1 = require("@midwayjs/core");
|
|
15
|
-
const CrudPro_1 = require("../../libs/crud-pro/CrudPro");
|
|
16
|
-
const MySQLUtils_1 = require("../../libs/crud-pro/utils/pool/MySQLUtils");
|
|
17
|
-
const PostgresUtils_1 = require("../../libs/crud-pro/utils/pool/PostgresUtils");
|
|
18
|
-
const SqlServerUtils_1 = require("../../libs/crud-pro/utils/pool/SqlServerUtils");
|
|
19
|
-
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
20
|
-
const exceptions_1 = require("../../libs/crud-pro/exceptions");
|
|
21
|
-
const ExecuteContextFunc_1 = require("../../libs/crud-pro/models/ExecuteContextFunc");
|
|
22
|
-
const BaseService_1 = require("../base/BaseService");
|
|
23
|
-
const CrudProQuick_1 = require("../../service/curd/CrudProQuick");
|
|
24
|
-
const fixCfgModel_1 = require("./fixCfgModel");
|
|
25
|
-
const global_config_1 = require("../../libs/global-config/global-config");
|
|
26
|
-
function toVisitor(ctx) {
|
|
27
|
-
const workbenchInfo = ctx.workbenchInfo;
|
|
28
|
-
const userSession = ctx.userSession;
|
|
29
|
-
if (!userSession || !userSession.isLogin()) {
|
|
30
|
-
return {
|
|
31
|
-
isLogin: false,
|
|
32
|
-
isSuperAdmin: false,
|
|
33
|
-
accountId: '0',
|
|
34
|
-
nickName: '匿名用户',
|
|
35
|
-
avatar: '',
|
|
36
|
-
accountType: '',
|
|
37
|
-
roleCodes: [],
|
|
38
|
-
functionCodes: [],
|
|
39
|
-
workbenchCode: (workbenchInfo === null || workbenchInfo === void 0 ? void 0 : workbenchInfo.workbench_code) || '',
|
|
40
|
-
};
|
|
41
|
-
}
|
|
42
|
-
const sessionInfo = userSession.getSessionInfo();
|
|
43
|
-
return {
|
|
44
|
-
isLogin: true,
|
|
45
|
-
isSuperAdmin: userSession.isSuperAdmin(),
|
|
46
|
-
accountId: sessionInfo.accountId,
|
|
47
|
-
nickName: sessionInfo.nickName,
|
|
48
|
-
avatar: sessionInfo.avatar,
|
|
49
|
-
accountType: sessionInfo.accountType,
|
|
50
|
-
roleCodes: sessionInfo.roleCodes || [],
|
|
51
|
-
functionCodes: sessionInfo.functionCodes || [],
|
|
52
|
-
workbenchCode: (workbenchInfo === null || workbenchInfo === void 0 ? void 0 : workbenchInfo.workbench_code) || '',
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
class MyContextFunc extends ExecuteContextFunc_1.BaseExecuteContextFunc {
|
|
56
|
-
constructor(cfgMap, responseCfgHandlers) {
|
|
57
|
-
super();
|
|
58
|
-
const { mysql2Config, postgres2Config, sqlserver2Config } = cfgMap;
|
|
59
|
-
this.mysql2Config = mysql2Config;
|
|
60
|
-
this.postgres2Config = postgres2Config;
|
|
61
|
-
this.sqlserver2Config = sqlserver2Config;
|
|
62
|
-
this.responseCfgHandlers = responseCfgHandlers;
|
|
63
|
-
}
|
|
64
|
-
async getConnectionPool(sqlCfgModel) {
|
|
65
|
-
if (!sqlCfgModel.sqlDatabase) {
|
|
66
|
-
console.error('[MyContextFunc]查询语句中未指定数据库', sqlCfgModel.executeSql);
|
|
67
|
-
throw new exceptions_1.CommonException(exceptions_1.Exceptions.DB_QUERY_PARAM_EMPTY, '查询语句中未指定数据库');
|
|
68
|
-
}
|
|
69
|
-
const dataBaseName = sqlCfgModel.sqlDatabase;
|
|
70
|
-
const sqlDbType = sqlCfgModel.sqlDbType;
|
|
71
|
-
if (sqlDbType === keys_1.SqlDbType.postgres) {
|
|
72
|
-
const dbConfig = _.get(this.postgres2Config, dataBaseName);
|
|
73
|
-
if (!dbConfig) {
|
|
74
|
-
console.error('[MyContextFunc]postgres配置中不存在此数据库', JSON.stringify(sqlCfgModel));
|
|
75
|
-
throw new exceptions_1.CommonException(exceptions_1.Exceptions.DB_NOT_FOUND, 'postgres配置中不存在此数据库:' + dataBaseName);
|
|
76
|
-
}
|
|
77
|
-
return (0, PostgresUtils_1.getConnectionPool)(dataBaseName, dbConfig);
|
|
78
|
-
}
|
|
79
|
-
if (sqlDbType === keys_1.SqlDbType.sqlserver) {
|
|
80
|
-
const dbConfig = _.get(this.sqlserver2Config, dataBaseName);
|
|
81
|
-
if (!dbConfig) {
|
|
82
|
-
console.error('[MyContextFunc]sqlserver配置中不存在此数据库', JSON.stringify(sqlCfgModel));
|
|
83
|
-
throw new exceptions_1.CommonException(exceptions_1.Exceptions.DB_NOT_FOUND, 'sqlserver配置中不存在此数据库:' + dataBaseName);
|
|
84
|
-
}
|
|
85
|
-
return (0, SqlServerUtils_1.getConnectionPool)(dataBaseName, dbConfig);
|
|
86
|
-
}
|
|
87
|
-
const dbConfig = _.get(this.mysql2Config, dataBaseName);
|
|
88
|
-
if (!dbConfig) {
|
|
89
|
-
console.error('[MyContextFunc]MySQL配置中不存在此数据库', JSON.stringify(sqlCfgModel));
|
|
90
|
-
throw new exceptions_1.CommonException(exceptions_1.Exceptions.DB_NOT_FOUND, 'MySQL配置中不存在此数据库:' + dataBaseName);
|
|
91
|
-
}
|
|
92
|
-
return (0, MySQLUtils_1.getConnectionPool)(dataBaseName, dbConfig);
|
|
93
|
-
}
|
|
94
|
-
async afterExecuteSQLList() {
|
|
95
|
-
const exeCtx = this.getExecuteContext();
|
|
96
|
-
const handlers = Object.values(this.responseCfgHandlers);
|
|
97
|
-
for (let i = 0; i < handlers.length; i++) {
|
|
98
|
-
const handler = handlers[i];
|
|
99
|
-
await handler.handleExecuteContextPrepare(exeCtx);
|
|
100
|
-
await handler.handleExecuteContext(exeCtx);
|
|
101
|
-
}
|
|
102
|
-
return null;
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* 在执行之前可以根据业务需要修改需要执行的内容
|
|
106
|
-
* @param reqJson
|
|
107
|
-
* @param cfgJson
|
|
108
|
-
*/
|
|
109
|
-
async beforeExecuteSQLList(reqJson, cfgJson) {
|
|
110
|
-
const { bizUpdateCfgModelForCrudPro } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
111
|
-
if (typeof bizUpdateCfgModelForCrudPro === 'function') {
|
|
112
|
-
await bizUpdateCfgModelForCrudPro(reqJson, cfgJson);
|
|
113
|
-
}
|
|
114
|
-
return Promise.resolve();
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
let CurdProService = class CurdProService extends BaseService_1.BaseService {
|
|
118
|
-
constructor() {
|
|
119
|
-
super(...arguments);
|
|
120
|
-
this.responseCfgHandlers = {};
|
|
121
|
-
}
|
|
122
|
-
setResponseCfgHandlers(key, handler) {
|
|
123
|
-
this.responseCfgHandlers[key] = handler;
|
|
124
|
-
}
|
|
125
|
-
getResponseCfgHandlers() {
|
|
126
|
-
return this.responseCfgHandlers;
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* Execute级别:每次调用都会产生新的
|
|
130
|
-
* @private
|
|
131
|
-
*/
|
|
132
|
-
getCrudPro() {
|
|
133
|
-
const visitor = toVisitor(this.ctx);
|
|
134
|
-
this.logInfo('visitor', JSON.stringify(visitor));
|
|
135
|
-
const crudPro = new CrudPro_1.CrudPro();
|
|
136
|
-
crudPro.transaction = this.ctx.transaction;
|
|
137
|
-
crudPro.logger = this.getContextLogger();
|
|
138
|
-
crudPro.visitor = visitor;
|
|
139
|
-
const crudProCfg = this.crudProCfg || {};
|
|
140
|
-
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
141
|
-
crudProCfg.sysDatabaseName = SystemDbName;
|
|
142
|
-
crudProCfg.sysDatabaseDbType = SystemDbType;
|
|
143
|
-
crudPro.contextCfg = crudProCfg;
|
|
144
|
-
crudPro.contextFunc = new MyContextFunc({
|
|
145
|
-
mysql2Config: this.mysql2Config,
|
|
146
|
-
postgres2Config: this.postgres2Config,
|
|
147
|
-
sqlserver2Config: this.sqlserver2Config,
|
|
148
|
-
}, this.responseCfgHandlers);
|
|
149
|
-
return crudPro;
|
|
150
|
-
}
|
|
151
|
-
/**
|
|
152
|
-
* 依赖缓存中与加载的配置
|
|
153
|
-
* @param reqJson
|
|
154
|
-
*/
|
|
155
|
-
async executeCrud(reqJson) {
|
|
156
|
-
if (!reqJson.method) {
|
|
157
|
-
throw new Error('Method not implemented');
|
|
158
|
-
}
|
|
159
|
-
const curdPro = this.getCrudPro();
|
|
160
|
-
// 开发环境不使用缓存
|
|
161
|
-
const isEnableCache = !this.isEnableDebug();
|
|
162
|
-
return curdPro.executeCrud(reqJson, isEnableCache);
|
|
163
|
-
}
|
|
164
|
-
// 直接执行一个SQL
|
|
165
|
-
async executeSQL(sqlCfgModel) {
|
|
166
|
-
const curdPro = this.getCrudPro();
|
|
167
|
-
return curdPro.executeSQL(sqlCfgModel);
|
|
168
|
-
}
|
|
169
|
-
// 直接执行一个请求
|
|
170
|
-
async executeCrudByCfg(reqJson, cfgModel) {
|
|
171
|
-
this.logInfo('executeCrudByCfg', cfgModel);
|
|
172
|
-
const curdPro = this.getCrudPro();
|
|
173
|
-
// 应用标准的updateCfg。
|
|
174
|
-
(0, fixCfgModel_1.fixCfgModel)(cfgModel);
|
|
175
|
-
return await curdPro.executeCrudByCfg(reqJson, cfgModel);
|
|
176
|
-
}
|
|
177
|
-
getBbUtil(sqlDatabase, sqlDbType, sqlTable) {
|
|
178
|
-
const curdPro = this.getCrudPro();
|
|
179
|
-
return new CrudProQuick_1.CrudProQuick(curdPro, sqlDatabase, sqlDbType, sqlTable);
|
|
180
|
-
}
|
|
181
|
-
async getCachedCfgByMethod(method) {
|
|
182
|
-
const curdPro = this.getCrudPro();
|
|
183
|
-
const isEnableCache = !this.isEnableDebug(); // 开发环境不使用缓存
|
|
184
|
-
return curdPro.getCachedCfgByMethod(method, isEnableCache);
|
|
185
|
-
}
|
|
186
|
-
};
|
|
187
|
-
__decorate([
|
|
188
|
-
(0, core_1.Inject)(),
|
|
189
|
-
__metadata("design:type", Object)
|
|
190
|
-
], CurdProService.prototype, "ctx", void 0);
|
|
191
|
-
__decorate([
|
|
192
|
-
(0, core_1.Config)('mysql2'),
|
|
193
|
-
__metadata("design:type", Object)
|
|
194
|
-
], CurdProService.prototype, "mysql2Config", void 0);
|
|
195
|
-
__decorate([
|
|
196
|
-
(0, core_1.Config)('postgres2'),
|
|
197
|
-
__metadata("design:type", Object)
|
|
198
|
-
], CurdProService.prototype, "postgres2Config", void 0);
|
|
199
|
-
__decorate([
|
|
200
|
-
(0, core_1.Config)('sqlserver2'),
|
|
201
|
-
__metadata("design:type", Object)
|
|
202
|
-
], CurdProService.prototype, "sqlserver2Config", void 0);
|
|
203
|
-
__decorate([
|
|
204
|
-
(0, core_1.Config)('crudProCfg'),
|
|
205
|
-
__metadata("design:type", Object)
|
|
206
|
-
], CurdProService.prototype, "crudProCfg", void 0);
|
|
207
|
-
CurdProService = __decorate([
|
|
208
|
-
(0, core_1.Provide)()
|
|
209
|
-
], CurdProService);
|
|
210
|
-
exports.CurdProService = CurdProService;
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.fixCfgModel = void 0;
|
|
4
|
-
const bizmodels_1 = require("../../models/bizmodels");
|
|
5
|
-
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
6
|
-
function isSimpleQuery(sqlSimpleName) {
|
|
7
|
-
return sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_QUERY ||
|
|
8
|
-
sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_COUNT ||
|
|
9
|
-
sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE ||
|
|
10
|
-
sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_ONE;
|
|
11
|
-
}
|
|
12
|
-
function fixCfgModel(cfgModel) {
|
|
13
|
-
if (!cfgModel.method) {
|
|
14
|
-
cfgModel.method = 'anonymous';
|
|
15
|
-
}
|
|
16
|
-
if (!cfgModel.updateCfg) {
|
|
17
|
-
cfgModel.updateCfg = {};
|
|
18
|
-
}
|
|
19
|
-
const sqlSimpleName = cfgModel.sqlSimpleName;
|
|
20
|
-
const enableStandardUpdateCfg = cfgModel.enableStandardUpdateCfg; // 用于设置data字段
|
|
21
|
-
const enableStandardUpdateCfgCondition = cfgModel.enableStandardUpdateCfgCondition; // 用于设置condition字段
|
|
22
|
-
// 彻底关闭
|
|
23
|
-
if (enableStandardUpdateCfg === false) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
const getDataCfgArray = () => {
|
|
27
|
-
// 明确有配置
|
|
28
|
-
if (Array.isArray(enableStandardUpdateCfg)) {
|
|
29
|
-
if (enableStandardUpdateCfg.includes('null')) {
|
|
30
|
-
return [];
|
|
31
|
-
}
|
|
32
|
-
return enableStandardUpdateCfg;
|
|
33
|
-
}
|
|
34
|
-
// update 、insert 添加 by
|
|
35
|
-
return ['by']; // 创建/修改语句默认添加by
|
|
36
|
-
};
|
|
37
|
-
const getConditionCfgArray = () => {
|
|
38
|
-
// 明确有配置
|
|
39
|
-
if (Array.isArray(enableStandardUpdateCfgCondition)) {
|
|
40
|
-
if (enableStandardUpdateCfgCondition.includes('null')) {
|
|
41
|
-
return [];
|
|
42
|
-
}
|
|
43
|
-
return enableStandardUpdateCfgCondition;
|
|
44
|
-
}
|
|
45
|
-
return [];
|
|
46
|
-
};
|
|
47
|
-
const dataCfgArray = getDataCfgArray();
|
|
48
|
-
const conditionCfgArray = getConditionCfgArray();
|
|
49
|
-
const mapping = {
|
|
50
|
-
'condition.created_by': { contextAsString: bizmodels_1.CTX_VISITOR_ID },
|
|
51
|
-
'condition.created_account_type': { contextAsString: bizmodels_1.CTX_VISITOR_ACCOUNT_TYPE },
|
|
52
|
-
'data.created_by': { contextAsString: bizmodels_1.CTX_VISITOR_ID },
|
|
53
|
-
'data.created_avatar': { contextAsString: bizmodels_1.CTX_VISITOR_AVATAR },
|
|
54
|
-
'data.created_nickname': { contextAsString: bizmodels_1.CTX_VISITOR_NICKNAME },
|
|
55
|
-
'data.created_account_type': { contextAsString: bizmodels_1.CTX_VISITOR_ACCOUNT_TYPE },
|
|
56
|
-
'data.modified_by': { contextAsString: bizmodels_1.CTX_VISITOR_ID },
|
|
57
|
-
'data.modified_avatar': { contextAsString: bizmodels_1.CTX_VISITOR_AVATAR },
|
|
58
|
-
'data.modified_nickname': { contextAsString: bizmodels_1.CTX_VISITOR_NICKNAME },
|
|
59
|
-
'data.modified_account_type': { contextAsString: bizmodels_1.CTX_VISITOR_ACCOUNT_TYPE },
|
|
60
|
-
};
|
|
61
|
-
const buildUpdateCfgBy = (cfgArray, prefix) => {
|
|
62
|
-
const obj = {};
|
|
63
|
-
if (Array.isArray(cfgArray)) {
|
|
64
|
-
for (let i = 0; i < cfgArray.length; i++) {
|
|
65
|
-
const suffix = cfgArray[i];
|
|
66
|
-
if (suffix) {
|
|
67
|
-
const key = `${prefix}_${suffix}`;
|
|
68
|
-
obj[key] = mapping[key];
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
return obj;
|
|
73
|
-
};
|
|
74
|
-
// 查询语句
|
|
75
|
-
if (isSimpleQuery(sqlSimpleName)) {
|
|
76
|
-
const updateCfgObj = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 查询用户本人创建的
|
|
77
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj);
|
|
78
|
-
}
|
|
79
|
-
// 删除语句
|
|
80
|
-
if (sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_DELETE) {
|
|
81
|
-
const updateCfgObj = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 删除用户本人创建的
|
|
82
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj);
|
|
83
|
-
}
|
|
84
|
-
// 插入语句
|
|
85
|
-
if (sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_INSERT) {
|
|
86
|
-
const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray, 'data.created');
|
|
87
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj1);
|
|
88
|
-
}
|
|
89
|
-
// 更新语句
|
|
90
|
-
if (sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE) {
|
|
91
|
-
const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray, 'data.modified');
|
|
92
|
-
const updateCfgObj2 = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 更新用户本人创建的
|
|
93
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj1);
|
|
94
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj2);
|
|
95
|
-
}
|
|
96
|
-
// 插入或更新
|
|
97
|
-
if (sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE ||
|
|
98
|
-
sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE) {
|
|
99
|
-
const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray, 'data.created');
|
|
100
|
-
const updateCfgObj2 = buildUpdateCfgBy(dataCfgArray, 'data.modified');
|
|
101
|
-
const updateCfgObj3 = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 更新用户本人创建的
|
|
102
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj1);
|
|
103
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj2);
|
|
104
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj3);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
exports.fixCfgModel = fixCfgModel;
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Context } from '@midwayjs/koa';
|
|
2
|
-
import { BaseService } from '../base/BaseService';
|
|
3
|
-
import { RouteTrie } from './RouteTrie';
|
|
4
|
-
import { IScheduleService } from '../../interface';
|
|
5
|
-
/**
|
|
6
|
-
* 接口代理。 数据加载
|
|
7
|
-
*/
|
|
8
|
-
export declare class ProxyApiLoadService extends BaseService implements IScheduleService {
|
|
9
|
-
protected ctx: Context;
|
|
10
|
-
private curdProService;
|
|
11
|
-
private workbenchService;
|
|
12
|
-
/**
|
|
13
|
-
* 创建路由树。刷新路由缓存
|
|
14
|
-
* @param workbench_code
|
|
15
|
-
*/
|
|
16
|
-
buildRouteTrie(workbench_code: string): Promise<RouteTrie>;
|
|
17
|
-
private buildUpstreamMap;
|
|
18
|
-
private loadProxyApiEntity;
|
|
19
|
-
private addUpstreamInfo;
|
|
20
|
-
runBySchedule(): Promise<any>;
|
|
21
|
-
}
|