midway-fatcms 0.0.1-beta.4 → 0.0.1-beta.41
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 -0
- package/.prettierrc.js +4 -0
- package/README.md +7 -0
- package/dist/config/config.default.js +58 -15
- package/dist/config/seed/aeskey.txt +1 -1
- package/dist/configuration.d.ts +1 -0
- package/dist/configuration.js +33 -9
- package/dist/controller/base/BaseApiController.d.ts +7 -1
- package/dist/controller/base/BaseApiController.js +32 -6
- package/dist/controller/gateway/AsyncTaskController.d.ts +20 -0
- package/dist/controller/gateway/AsyncTaskController.js +181 -0
- package/dist/controller/gateway/CrudMtdGatewayController.d.ts +3 -3
- package/dist/controller/gateway/CrudMtdGatewayController.js +9 -6
- package/dist/controller/gateway/DocGatewayController.js +14 -9
- package/dist/controller/gateway/FileController.d.ts +3 -2
- package/dist/controller/gateway/PublicApiController.js +4 -6
- package/dist/controller/gateway/StaticController.d.ts +0 -1
- package/dist/controller/gateway/StaticController.js +40 -39
- package/dist/controller/helpers.controller.d.ts +1 -1
- package/dist/controller/home.controller.js +4 -3
- package/dist/controller/manage/AnyApiMangeApi.js +2 -2
- package/dist/controller/manage/AppLogMangeApi.js +2 -2
- package/dist/controller/manage/AppMangeApi.js +2 -2
- package/dist/controller/manage/AppPageMangeApi.js +2 -2
- package/dist/controller/manage/AppSchemaHistoryApi.js +2 -2
- package/dist/controller/manage/CrudMethodsMangeApi.js +2 -2
- package/dist/controller/manage/CrudStandardDesignApi.d.ts +1 -1
- package/dist/controller/manage/CrudStandardDesignApi.js +86 -83
- package/dist/controller/manage/DataDictManageApi.d.ts +1 -1
- package/dist/controller/manage/DataDictManageApi.js +1 -1
- package/dist/controller/manage/DeployManageApi.d.ts +1 -1
- package/dist/controller/manage/DeployManageApi.js +38 -34
- package/dist/controller/manage/DocLibManageApi.js +2 -2
- package/dist/controller/manage/DocManageApi.js +2 -2
- package/dist/controller/manage/FileManageApi.js +1 -1
- package/dist/controller/manage/LowCodeTplManageApi.js +2 -2
- package/dist/controller/manage/MenuManageApi.js +2 -2
- package/dist/controller/manage/ProxyApiMangeApi.js +2 -2
- package/dist/controller/manage/SuperAdminManageApi.d.ts +2 -2
- package/dist/controller/manage/SuperAdminManageApi.js +12 -8
- package/dist/controller/manage/SysConfigMangeApi.d.ts +1 -1
- package/dist/controller/manage/SysConfigMangeApi.js +8 -6
- package/dist/controller/manage/SystemInfoManageApi.d.ts +1 -1
- package/dist/controller/manage/SystemInfoManageApi.js +7 -1
- package/dist/controller/manage/UserAccountManageApi.d.ts +2 -2
- package/dist/controller/manage/UserAccountManageApi.js +7 -2
- package/dist/controller/manage/WorkbenchMangeApi.js +3 -3
- package/dist/controller/myinfo/AuthController.d.ts +0 -4
- package/dist/controller/myinfo/AuthController.js +1 -54
- package/dist/controller/render/AppRenderController.js +12 -5
- package/dist/controller/test.controller.d.ts +1 -1
- package/dist/controller/test.controller.js +5 -5
- package/dist/index.d.ts +35 -4
- package/dist/index.js +35 -4
- package/dist/libs/crud-pro/CrudPro.d.ts +1 -0
- package/dist/libs/crud-pro/CrudPro.js +5 -0
- package/dist/libs/crud-pro/defaultConfigs.js +2 -0
- package/dist/libs/crud-pro/interfaces.d.ts +7 -1
- package/dist/libs/crud-pro/models/ExecuteContext.d.ts +12 -5
- package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +8 -1
- package/dist/libs/crud-pro/models/ExecuteContextFunc.js +8 -0
- package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +1 -1
- package/dist/libs/crud-pro/models/ResModel.d.ts +16 -0
- package/dist/libs/crud-pro/models/ResModel.js +2 -0
- package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +1 -1
- package/dist/libs/crud-pro/models/Transaction.d.ts +1 -0
- package/dist/libs/crud-pro/models/Transaction.js +7 -0
- package/dist/libs/crud-pro/models/TransactionSqlServer.js +1 -1
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +1 -0
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +27 -15
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +17 -19
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +1 -1
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +10 -12
- package/dist/libs/crud-pro/services/CrudProGenSqlService.js +14 -23
- package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +7 -6
- package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +2 -6
- package/dist/libs/crud-pro/services/CrudProServiceBase.js +15 -3
- package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +1 -0
- package/dist/libs/crud-pro/services/CrudProTableMetaService.js +32 -7
- package/dist/libs/crud-pro/sql.txt +120 -120
- package/dist/libs/crud-pro/utils/DatabaseName.js +24 -3
- package/dist/libs/crud-pro/utils/MixinUtils.js +1 -1
- package/dist/libs/crud-pro/utils/ValidateUtils.js +1 -1
- package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +2 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -0
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -0
- package/dist/libs/global-config/global-config.d.ts +45 -0
- package/dist/libs/global-config/global-config.js +33 -0
- package/dist/libs/utils/base64.d.ts +9 -0
- package/dist/libs/utils/base64.js +42 -0
- package/dist/libs/utils/errorToString.d.ts +2 -0
- package/dist/libs/utils/errorToString.js +57 -0
- package/dist/libs/utils/fatcms-request.js +2 -2
- package/dist/libs/utils/functions.d.ts +2 -1
- package/dist/libs/utils/functions.js +6 -1
- package/dist/middleware/forbidden.middleware.js +4 -20
- package/dist/middleware/global.middleware.js +30 -10
- package/dist/middleware/permission.middleware.js +1 -1
- package/dist/models/AsyncTaskModel.d.ts +74 -0
- package/dist/models/AsyncTaskModel.js +31 -0
- package/dist/models/RedisKeys.d.ts +14 -0
- package/dist/models/RedisKeys.js +17 -0
- package/dist/models/SystemEntities.d.ts +8 -1
- package/dist/models/SystemEntities.js +7 -0
- package/dist/models/SystemTables.d.ts +1 -3
- package/dist/models/SystemTables.js +2 -4
- package/dist/models/bizmodels.d.ts +28 -0
- package/dist/models/bizmodels.js +6 -1
- package/dist/schedule/anonymousContext.d.ts +14 -0
- package/dist/schedule/anonymousContext.js +59 -0
- package/dist/schedule/index.d.ts +4 -3
- package/dist/schedule/index.js +8 -67
- package/dist/schedule/runSchedule.d.ts +12 -0
- package/dist/schedule/runSchedule.js +68 -0
- package/dist/schedule/scheduleNames.d.ts +13 -0
- package/dist/schedule/scheduleNames.js +17 -0
- package/dist/service/AuthService.js +8 -5
- package/dist/service/EnumInfoService.js +9 -5
- package/dist/service/FileCenterService.js +13 -9
- package/dist/service/SysConfigService.d.ts +1 -1
- package/dist/service/SysConfigService.js +4 -2
- package/dist/service/UserAccountService.js +10 -6
- package/dist/service/UserSessionService.d.ts +21 -0
- package/dist/service/UserSessionService.js +73 -2
- package/dist/service/VisitStatService.d.ts +1 -1
- package/dist/service/VisitStatService.js +20 -27
- package/dist/service/WorkbenchService.d.ts +33 -0
- package/dist/service/WorkbenchService.js +70 -12
- package/dist/service/anyapi/AnyApiSandboxService.js +12 -12
- package/dist/service/anyapi/AnyApiService.js +4 -2
- package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -0
- package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -0
- package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -0
- package/dist/service/asyncTask/AsyncTaskService.js +34 -0
- package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
- package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -0
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +139 -0
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +121 -0
- package/dist/service/base/BaseService.d.ts +12 -0
- package/dist/service/base/BaseService.js +22 -0
- package/dist/service/base/RedisCacheService.d.ts +7 -0
- package/dist/service/base/RedisCacheService.js +7 -0
- package/dist/service/crudstd/CrudStdService.d.ts +8 -1
- package/dist/service/crudstd/CrudStdService.js +63 -6
- package/dist/service/curd/CrudProQuick.d.ts +44 -0
- package/dist/service/curd/CrudProQuick.js +147 -0
- package/dist/service/curd/CurdMixByAccountService.d.ts +4 -4
- package/dist/service/curd/CurdMixByAccountService.js +12 -6
- package/dist/service/curd/CurdMixByDictService.d.ts +4 -4
- package/dist/service/curd/CurdMixByDictService.js +10 -7
- package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +13 -4
- package/dist/service/curd/CurdMixByLinkToCustomService.js +73 -24
- package/dist/service/curd/CurdMixBySysConfigService.d.ts +3 -3
- package/dist/service/curd/CurdMixBySysConfigService.js +4 -2
- package/dist/service/curd/CurdMixByWorkbenchService.d.ts +3 -3
- package/dist/service/curd/CurdMixByWorkbenchService.js +4 -2
- package/dist/service/curd/CurdMixService.d.ts +13 -3
- package/dist/service/curd/CurdMixService.js +26 -2
- package/dist/service/curd/CurdMixUtils.d.ts +27 -4
- package/dist/service/curd/CurdMixUtils.js +115 -41
- package/dist/service/curd/CurdProService.d.ts +3 -10
- package/dist/service/curd/CurdProService.js +36 -148
- package/dist/service/curd/fixCfgModel.d.ts +3 -0
- package/dist/service/curd/fixCfgModel.js +107 -0
- package/dist/service/proxyapi/ProxyApiLoadService.js +7 -4
- package/dist/service/proxyapi/ProxyApiService.d.ts +1 -0
- package/dist/service/proxyapi/ProxyApiService.js +43 -9
- package/dist/views/404_app.html +31 -31
- package/dist/views/404_workbench.html +34 -34
- package/package.json +28 -24
- package/tsconfig.json +32 -0
- package/dist/controller/medstatistic/MedAdminController.d.ts +0 -35
- package/dist/controller/medstatistic/MedAdminController.js +0 -205
- package/dist/controller/medstatistic/MedClientController.d.ts +0 -28
- package/dist/controller/medstatistic/MedClientController.js +0 -188
- package/dist/controller/medstatistic/MedMessageService.d.ts +0 -19
- package/dist/controller/medstatistic/MedMessageService.js +0 -95
- package/dist/controller/medstatistic/MedScoreService.d.ts +0 -21
- package/dist/controller/medstatistic/MedScoreService.js +0 -107
- package/dist/controller/medstatistic/constants.d.ts +0 -32
- package/dist/controller/medstatistic/constants.js +0 -43
- package/src/config/config.default.ts +0 -172
- package/src/config/seed/aeskey.txt +0 -1
- package/src/config/utils.ts +0 -23
- package/src/configuration.ts +0 -83
- package/src/controller/base/BaseApiController.ts +0 -145
- package/src/controller/gateway/AnyApiGatewayController.ts +0 -33
- package/src/controller/gateway/CrudMtdGatewayController.ts +0 -107
- package/src/controller/gateway/CrudStdGatewayController.ts +0 -101
- package/src/controller/gateway/DocGatewayController.ts +0 -165
- package/src/controller/gateway/FileController.ts +0 -110
- package/src/controller/gateway/ProxyApiGatewayController.ts +0 -47
- package/src/controller/gateway/PublicApiController.ts +0 -145
- package/src/controller/gateway/StaticController.ts +0 -328
- package/src/controller/helpers.controller.ts +0 -161
- package/src/controller/home.controller.ts +0 -71
- package/src/controller/manage/AnyApiMangeApi.ts +0 -66
- package/src/controller/manage/AppLogMangeApi.ts +0 -53
- package/src/controller/manage/AppMangeApi.ts +0 -53
- package/src/controller/manage/AppPageMangeApi.ts +0 -52
- package/src/controller/manage/AppSchemaHistoryApi.ts +0 -49
- package/src/controller/manage/CrudMethodsMangeApi.ts +0 -49
- package/src/controller/manage/CrudStandardDesignApi.ts +0 -353
- package/src/controller/manage/DataDictManageApi.ts +0 -78
- package/src/controller/manage/DeployManageApi.ts +0 -179
- package/src/controller/manage/DocLibManageApi.ts +0 -69
- package/src/controller/manage/DocManageApi.ts +0 -99
- package/src/controller/manage/FileManageApi.ts +0 -45
- package/src/controller/manage/LowCodeTplManageApi.ts +0 -52
- package/src/controller/manage/MenuManageApi.ts +0 -63
- package/src/controller/manage/ProxyApiMangeApi.ts +0 -52
- package/src/controller/manage/SuperAdminManageApi.ts +0 -138
- package/src/controller/manage/SysConfigMangeApi.ts +0 -95
- package/src/controller/manage/SystemInfoManageApi.ts +0 -48
- package/src/controller/manage/UserAccountManageApi.ts +0 -88
- package/src/controller/manage/WorkbenchMangeApi.ts +0 -72
- package/src/controller/medstatistic/MedAdminController.ts +0 -221
- package/src/controller/medstatistic/MedClientController.ts +0 -188
- package/src/controller/medstatistic/MedMessageService.ts +0 -89
- package/src/controller/medstatistic/MedScoreService.ts +0 -108
- package/src/controller/medstatistic/constants.ts +0 -63
- package/src/controller/myinfo/AuthController.ts +0 -174
- package/src/controller/myinfo/MyInfoController.ts +0 -32
- package/src/controller/render/AppRenderController.ts +0 -76
- package/src/controller/test.controller.ts +0 -37
- package/src/filter/default.filter.ts +0 -13
- package/src/filter/notfound.filter.ts +0 -10
- package/src/index.ts +0 -71
- package/src/interface.ts +0 -31
- package/src/libs/crud-pro/CrudPro.ts +0 -158
- package/src/libs/crud-pro/defaultConfigs.ts +0 -13
- package/src/libs/crud-pro/exceptions.ts +0 -124
- package/src/libs/crud-pro/interfaces.ts +0 -183
- package/src/libs/crud-pro/models/ExecuteContext.ts +0 -111
- package/src/libs/crud-pro/models/ExecuteContextFunc.ts +0 -86
- package/src/libs/crud-pro/models/FuncContext.ts +0 -21
- package/src/libs/crud-pro/models/RequestCfgModel.ts +0 -141
- package/src/libs/crud-pro/models/RequestModel.ts +0 -141
- package/src/libs/crud-pro/models/ServiceHub.ts +0 -32
- package/src/libs/crud-pro/models/SqlCfgModel.ts +0 -52
- package/src/libs/crud-pro/models/SqlSegArg.ts +0 -13
- package/src/libs/crud-pro/models/Transaction.ts +0 -74
- package/src/libs/crud-pro/models/TransactionMySQL.ts +0 -79
- package/src/libs/crud-pro/models/TransactionPostgres.ts +0 -91
- package/src/libs/crud-pro/models/TransactionSqlServer.ts +0 -107
- package/src/libs/crud-pro/models/keys.ts +0 -159
- package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +0 -75
- package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +0 -128
- package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +0 -279
- package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +0 -60
- package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +0 -180
- package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +0 -373
- package/src/libs/crud-pro/services/CrudProGenSqlService.ts +0 -202
- package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +0 -397
- package/src/libs/crud-pro/services/CrudProServiceBase.ts +0 -98
- package/src/libs/crud-pro/services/CrudProTableMetaService.ts +0 -59
- package/src/libs/crud-pro/services/CurdProServiceHub.ts +0 -92
- package/src/libs/crud-pro/sql.txt +0 -120
- package/src/libs/crud-pro/utils/CompareUtils.ts +0 -23
- package/src/libs/crud-pro/utils/DatabaseName.ts +0 -40
- package/src/libs/crud-pro/utils/DateTimeUtils.ts +0 -20
- package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +0 -64
- package/src/libs/crud-pro/utils/MessageParseUtils.ts +0 -33
- package/src/libs/crud-pro/utils/MixinUtils.ts +0 -285
- package/src/libs/crud-pro/utils/ModelUtils.ts +0 -55
- package/src/libs/crud-pro/utils/MultiKeyMap.ts +0 -72
- package/src/libs/crud-pro/utils/SqlFuncUtils.ts +0 -29
- package/src/libs/crud-pro/utils/TypeUtils.ts +0 -188
- package/src/libs/crud-pro/utils/ValidateUtils.ts +0 -167
- package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +0 -20
- package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +0 -22
- package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +0 -22
- package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +0 -26
- package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +0 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +0 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +0 -129
- package/src/libs/utils/common-dto.ts +0 -52
- package/src/libs/utils/crypto-utils.ts +0 -52
- package/src/libs/utils/fatcms-request.ts +0 -115
- package/src/libs/utils/functions.ts +0 -67
- package/src/libs/utils/ordernum-utils.ts +0 -18
- package/src/libs/utils/parseConfig.ts +0 -62
- package/src/libs/utils/parseCreateSql.ts +0 -91
- package/src/libs/utils/render-utils.ts +0 -184
- package/src/middleware/forbidden.middleware.ts +0 -71
- package/src/middleware/global.middleware.ts +0 -278
- package/src/middleware/permission.middleware.ts +0 -81
- package/src/middleware/tx.middleware.ts +0 -30
- package/src/models/SystemEntities.ts +0 -115
- package/src/models/SystemPerm.ts +0 -105
- package/src/models/SystemTables.ts +0 -30
- package/src/models/bizmodels.ts +0 -89
- package/src/models/contextLogger.ts +0 -132
- package/src/models/devops.ts +0 -17
- package/src/models/userSession.ts +0 -216
- package/src/schedule/index.ts +0 -73
- package/src/service/AuthService.ts +0 -270
- package/src/service/EnumInfoService.ts +0 -129
- package/src/service/FileCenterService.ts +0 -394
- package/src/service/SysConfigService.ts +0 -34
- package/src/service/UserAccountService.ts +0 -100
- package/src/service/UserSessionService.ts +0 -81
- package/src/service/VisitStatService.ts +0 -179
- package/src/service/WorkbenchService.ts +0 -160
- package/src/service/anyapi/AnyApiSandboxService.ts +0 -121
- package/src/service/anyapi/AnyApiService.ts +0 -184
- package/src/service/base/ApiBaseService.ts +0 -42
- package/src/service/base/ApiRateLimiter.ts +0 -59
- package/src/service/base/BaseService.ts +0 -74
- package/src/service/base/RedisCacheService.ts +0 -38
- package/src/service/crudstd/CrudStdActionService.ts +0 -27
- package/src/service/crudstd/CrudStdConstant.ts +0 -62
- package/src/service/crudstd/CrudStdRelationService.ts +0 -78
- package/src/service/crudstd/CrudStdService.ts +0 -188
- package/src/service/curd/CurdMixByAccountService.ts +0 -83
- package/src/service/curd/CurdMixByDictService.ts +0 -113
- package/src/service/curd/CurdMixByLinkToCustomService.ts +0 -167
- package/src/service/curd/CurdMixBySysConfigService.ts +0 -78
- package/src/service/curd/CurdMixByWorkbenchService.ts +0 -68
- package/src/service/curd/CurdMixService.ts +0 -65
- package/src/service/curd/CurdMixUtils.ts +0 -248
- package/src/service/curd/CurdProService.ts +0 -379
- package/src/service/proxyapi/ProxyApiLoadService.ts +0 -165
- package/src/service/proxyapi/ProxyApiService.ts +0 -262
- package/src/service/proxyapi/ProxyApiUtils.ts +0 -32
- package/src/service/proxyapi/RouteHandler.ts +0 -8
- package/src/service/proxyapi/RouteTrie.ts +0 -74
- package/src/service/proxyapi/WeightedRandom.ts +0 -37
- package/src/service/proxyapi/WeightedRoundRobin.ts +0 -44
- package/src/views/404_app.html +0 -31
- package/src/views/404_workbench.html +0 -34
- package/src/views/static/favicon.ico +0 -0
|
@@ -1,202 +0,0 @@
|
|
|
1
|
-
import { CrudProServiceBase } from './CrudProServiceBase';
|
|
2
|
-
import { CommonException, Exceptions } from '../exceptions';
|
|
3
|
-
import { MixinUtils } from '../utils/MixinUtils';
|
|
4
|
-
import {KeysOfSimpleSQL, KeysOfSqlResPicker, SqlDbType} from '../models/keys';
|
|
5
|
-
import {RequestCfgModel} from "../models/RequestCfgModel";
|
|
6
|
-
|
|
7
|
-
const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils;
|
|
8
|
-
|
|
9
|
-
class CrudProGenSqlService extends CrudProServiceBase {
|
|
10
|
-
public async generateSQLList() {
|
|
11
|
-
const exeCtx = this.getExecuteContext();
|
|
12
|
-
const reqCfg = exeCtx.getCfgModel();
|
|
13
|
-
const sqlSimpleName = reqCfg.sqlSimpleName;
|
|
14
|
-
|
|
15
|
-
// 简单模式
|
|
16
|
-
const isSimpleMode = isNotEmpty(sqlSimpleName) && sqlSimpleName.startsWith('SIMPLE_');
|
|
17
|
-
|
|
18
|
-
// 拼接简单模式的SQL
|
|
19
|
-
if (isSimpleMode) {
|
|
20
|
-
this.generateOriginSql();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
await this.generateExecuteSql();
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
private generateOriginSql() {
|
|
27
|
-
const exeCtx = this.getExecuteContext();
|
|
28
|
-
|
|
29
|
-
const cfgModel = exeCtx.getCfgModel();
|
|
30
|
-
const simpleSqlName = cfgModel.sqlSimpleName;
|
|
31
|
-
|
|
32
|
-
// 只有当设置了simpleSqlName时,才启用内置的SQL生成
|
|
33
|
-
if (isEmpty(simpleSqlName)) {
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
cfgModel.sqlCfgList = [];
|
|
38
|
-
|
|
39
|
-
let sql1 = null;
|
|
40
|
-
let sql2 = null;
|
|
41
|
-
let sql3 = null;
|
|
42
|
-
if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY, simpleSqlName)) {
|
|
43
|
-
sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit';
|
|
44
|
-
cfgModel.addSqlCfgModel('rows', sql1);
|
|
45
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_ONE, simpleSqlName)) {
|
|
46
|
-
sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys limit 1';
|
|
47
|
-
cfgModel.addSqlCfgModel('row', sql1, KeysOfSqlResPicker.RESULT_FIRST_ROW);
|
|
48
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_COUNT, simpleSqlName)) {
|
|
49
|
-
sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition';
|
|
50
|
-
|
|
51
|
-
cfgModel.addSqlCfgModel('total_count', sql1, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
|
|
52
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_PAGE, simpleSqlName)) {
|
|
53
|
-
sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit ';
|
|
54
|
-
sql2 = 'select count(0) as total_count from @@table where @@asWhere:condition';
|
|
55
|
-
|
|
56
|
-
cfgModel.addSqlCfgModel('rows', sql1);
|
|
57
|
-
cfgModel.addSqlCfgModel('total_count', sql2, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
|
|
58
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_DELETE, simpleSqlName)) {
|
|
59
|
-
sql1 = this.generateOriginSqlForDelete(cfgModel);
|
|
60
|
-
cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
|
|
61
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT, simpleSqlName)) {
|
|
62
|
-
sql1 = this.generateOriginSqlForInsert(cfgModel);
|
|
63
|
-
cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
|
|
64
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_UPDATE, simpleSqlName)) {
|
|
65
|
-
sql1 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
|
|
66
|
-
cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
|
|
67
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE, simpleSqlName)) {
|
|
68
|
-
sql1 = this.generateOriginSqlForDuplicateInsert(cfgModel);
|
|
69
|
-
cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
|
|
70
|
-
} else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE, simpleSqlName)) {
|
|
71
|
-
sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition ';
|
|
72
|
-
sql2 = 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )';
|
|
73
|
-
sql3 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
|
|
74
|
-
|
|
75
|
-
const insertWhen2 = {
|
|
76
|
-
functionName: 'eq',
|
|
77
|
-
functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
|
|
78
|
-
};
|
|
79
|
-
const updateWhen3 = {
|
|
80
|
-
functionName: 'gt',
|
|
81
|
-
functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
|
|
82
|
-
};
|
|
83
|
-
|
|
84
|
-
cfgModel.addSqlCfgModel('total_count', sql1, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
|
|
85
|
-
cfgModel.addSqlCfgModel('insert_affected', sql2, KeysOfSqlResPicker.UPDATE_RESULT, insertWhen2);
|
|
86
|
-
cfgModel.addSqlCfgModel('update_affected', sql3, KeysOfSqlResPicker.UPDATE_RESULT, updateWhen3);
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
if (isEmpty(sql1)) {
|
|
90
|
-
throw new CommonException(Exceptions.CFG_NOT_SUPPORT_THE_SIMPLE_SQL, simpleSqlName);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
/**
|
|
95
|
-
* 删除语句
|
|
96
|
-
* @param cfgModel
|
|
97
|
-
* @private
|
|
98
|
-
*/
|
|
99
|
-
private generateOriginSqlForDelete(cfgModel: RequestCfgModel) : string {
|
|
100
|
-
if (cfgModel.sqlDdType === SqlDbType.postgres) {
|
|
101
|
-
return 'delete from @@table where @@asWhere:condition ';
|
|
102
|
-
}
|
|
103
|
-
if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
|
|
104
|
-
return 'delete from @@table where @@asWhere:condition ';
|
|
105
|
-
}
|
|
106
|
-
return 'delete from @@table where @@asWhere:condition limit 100 '; // 删除操作,不能一次性删除太多
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
/**
|
|
110
|
-
* 创建插入OR更新语句
|
|
111
|
-
* @param cfgModel
|
|
112
|
-
* @private
|
|
113
|
-
*/
|
|
114
|
-
private generateOriginSqlForDuplicateInsert(cfgModel: RequestCfgModel) : string {
|
|
115
|
-
if (cfgModel.sqlDdType === SqlDbType.postgres) {
|
|
116
|
-
const uniqueColumn = cfgModel.uniqueColumn ; // id
|
|
117
|
-
if (!Array.isArray(uniqueColumn) || uniqueColumn.length === 0) {
|
|
118
|
-
throw new CommonException(Exceptions.CFG_ERROR_POSTGRES_UNIQUE_COLUMNS_NULL)
|
|
119
|
-
}
|
|
120
|
-
const unique_column = uniqueColumn.map((s)=>{
|
|
121
|
-
return `"${s}"`;
|
|
122
|
-
}).join(",")
|
|
123
|
-
return `insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) ON CONFLICT (${unique_column}) DO UPDATE set @@asUpdate:data `; // 关键字的前后,必须有空格
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
|
|
128
|
-
const uniqueColumn = cfgModel.uniqueColumn ; // id
|
|
129
|
-
if (uniqueColumn.length !== 1) {
|
|
130
|
-
throw new CommonException(Exceptions.CFG_UNIQUE_COLUMN_COUNT_MUST_ONE);
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
const uniqueColumnStr = uniqueColumn[0];
|
|
134
|
-
const uniqueColumnVal = "@@data." + uniqueColumnStr;
|
|
135
|
-
|
|
136
|
-
const sql = "" +
|
|
137
|
-
`IF EXISTS (SELECT 1 FROM @@table WHERE [${uniqueColumnStr}] = ${uniqueColumnVal})` +
|
|
138
|
-
"BEGIN\n" +
|
|
139
|
-
" UPDATE @@table\n" +
|
|
140
|
-
" SET @@asUpdate:data\n" +
|
|
141
|
-
` WHERE [${uniqueColumnStr}] = ${uniqueColumnVal} ;\n` +
|
|
142
|
-
"END\n" +
|
|
143
|
-
"ELSE\n" +
|
|
144
|
-
"BEGIN\n" +
|
|
145
|
-
" INSERT INTO @@table ( @@asInsertKeys:data )\n" +
|
|
146
|
-
" VALUES ( @@asInsertValues:data );\n" +
|
|
147
|
-
"END";
|
|
148
|
-
|
|
149
|
-
return sql;
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) on duplicate key update @@asUpdate:data '; // 关键字的前后,必须有空格
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
/**
|
|
158
|
-
* 创建插入语句
|
|
159
|
-
* @param cfgModel
|
|
160
|
-
* @private
|
|
161
|
-
*/
|
|
162
|
-
private generateOriginSqlForInsert(cfgModel: RequestCfgModel): string {
|
|
163
|
-
if (cfgModel.sqlDdType === SqlDbType.postgres) {
|
|
164
|
-
return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) RETURNING * ';
|
|
165
|
-
}
|
|
166
|
-
if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
|
|
167
|
-
return 'insert into @@table ( @@asInsertKeys:data ) OUTPUT INSERTED.* values( @@asInsertValues:data ) ';
|
|
168
|
-
}
|
|
169
|
-
return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )'; // 关键字的前后,必须有空格
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
private async generateExecuteSql() {
|
|
176
|
-
const exeCtx = this.getExecuteContext();
|
|
177
|
-
|
|
178
|
-
const reqCfgModel = exeCtx.getCfgModel();
|
|
179
|
-
const sqlCfgList = reqCfgModel.sqlCfgList || [];
|
|
180
|
-
const { sqlTable, sqlSchema, sqlDatabase, sqlDdType, maxLimit, columns, columnsRelation } = reqCfgModel;
|
|
181
|
-
|
|
182
|
-
for (let i = 0; i < sqlCfgList.length; i++) {
|
|
183
|
-
const sqlCfgModel = sqlCfgList[i];
|
|
184
|
-
|
|
185
|
-
sqlCfgModel.sqlDdType = MixinUtils.selectNotEmpty(sqlCfgModel.sqlDdType, sqlDdType);
|
|
186
|
-
sqlCfgModel.sqlDatabase = MixinUtils.selectNotEmpty(sqlCfgModel.sqlDatabase, sqlDatabase);
|
|
187
|
-
sqlCfgModel.sqlSchema = MixinUtils.selectNotEmpty(sqlCfgModel.sqlSchema, sqlSchema);
|
|
188
|
-
sqlCfgModel.sqlTable = MixinUtils.selectNotEmpty(sqlCfgModel.sqlTable, sqlTable);
|
|
189
|
-
sqlCfgModel.maxLimit = MixinUtils.selectNotEmpty(sqlCfgModel.maxLimit, maxLimit);
|
|
190
|
-
sqlCfgModel.columns = MixinUtils.selectNotEmpty(sqlCfgModel.columns, columns);
|
|
191
|
-
sqlCfgModel.columnsRelation = MixinUtils.selectNotEmpty(sqlCfgModel.columnsRelation, columnsRelation);
|
|
192
|
-
|
|
193
|
-
await this.serviceHub.convertOriginToExecuteSql(sqlCfgModel);
|
|
194
|
-
|
|
195
|
-
exeCtx.getSqlCfgModels().push(sqlCfgModel);
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
export { CrudProGenSqlService };
|
|
@@ -1,397 +0,0 @@
|
|
|
1
|
-
import {CrudProServiceBase} from './CrudProServiceBase';
|
|
2
|
-
import {SqlCfgModel} from '../models/SqlCfgModel';
|
|
3
|
-
import {MixinUtils} from '../utils/MixinUtils';
|
|
4
|
-
import {SqlSegArg} from '../models/SqlSegArg';
|
|
5
|
-
import {KeysOfCustomSQL, SqlDbType} from '../models/keys';
|
|
6
|
-
import {RequestModel} from '../models/RequestModel';
|
|
7
|
-
import {CommonException, Exceptions} from '../exceptions';
|
|
8
|
-
import {RequestCfgModel} from '../models/RequestCfgModel';
|
|
9
|
-
import {ModelUtils} from '../utils/ModelUtils';
|
|
10
|
-
import {FuncContext} from '../models/FuncContext';
|
|
11
|
-
import {TypeUtils} from '../utils/TypeUtils';
|
|
12
|
-
import {sqlFuncUtils} from '../utils/SqlFuncUtils';
|
|
13
|
-
import {toSqlColumnName, toSqlColumnNamesJoin} from '../utils/sqlConvert/convertColumnName';
|
|
14
|
-
import {CrudProGenSqlCondition} from "./CrudProGenSqlCondition";
|
|
15
|
-
|
|
16
|
-
const KEYS_CUSTOM_PATTERN = /@@[0-9a-zA-Z:._]+/gm;
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* 存在任何需要排除的
|
|
21
|
-
* @param columns
|
|
22
|
-
*/
|
|
23
|
-
function isAnyStartWithExclude(columns: string[]): boolean {
|
|
24
|
-
if (MixinUtils.isEmpty(columns)) {
|
|
25
|
-
return false;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
for (let i = 0; i < columns.length; i++) {
|
|
29
|
-
const s = columns[i];
|
|
30
|
-
if (s.startsWith('!')) {
|
|
31
|
-
return true;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
return false;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
class CrudProOriginToExecuteSql extends CrudProServiceBase {
|
|
38
|
-
async convertOriginToExecuteSql(sqlCfgModel: SqlCfgModel) {
|
|
39
|
-
const originSql = sqlCfgModel.originSql;
|
|
40
|
-
if (MixinUtils.isEmpty(originSql)) {
|
|
41
|
-
// 允许配置中没有originSql,此时可能仅仅用来做校验逻辑
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
if (MixinUtils.isNotEmpty(sqlCfgModel.executeSql)) {
|
|
46
|
-
//直接传递可执行SQL ,不需要再转换。
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
const sqlArgModelMap = await this.generateWordMap(originSql, sqlCfgModel);
|
|
51
|
-
|
|
52
|
-
const argList = [];
|
|
53
|
-
let executeSql = originSql;
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
// 发现有需要被替换的变量。
|
|
57
|
-
if (sqlArgModelMap) {
|
|
58
|
-
executeSql = originSql.replace(KEYS_CUSTOM_PATTERN, word => {
|
|
59
|
-
if (!word) {
|
|
60
|
-
return '';
|
|
61
|
-
}
|
|
62
|
-
const sqlArgModel = sqlArgModelMap[word];
|
|
63
|
-
|
|
64
|
-
if (!sqlArgModel) {
|
|
65
|
-
return '';
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
if (MixinUtils.isNotEmpty(sqlArgModel.args) && Array.isArray(sqlArgModel.args)) {
|
|
69
|
-
argList.push(...sqlArgModel.args);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
return sqlArgModel.sql;
|
|
73
|
-
});
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
sqlCfgModel.executeSqlArgs = argList;
|
|
78
|
-
sqlCfgModel.executeSql = executeSql;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
private async generateWordMap(originSql: string, sqlCfgModel: SqlCfgModel): Promise<Record<string, SqlSegArg>> {
|
|
82
|
-
// ['@@columns', '@@table', '@@asWhere:condition', '@@orderBys']
|
|
83
|
-
const sqlKeywords = originSql.match(KEYS_CUSTOM_PATTERN);
|
|
84
|
-
|
|
85
|
-
// 没有需要被替换的变量。
|
|
86
|
-
if (!sqlKeywords || sqlKeywords.length === 0) {
|
|
87
|
-
return null;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
const sqlKeywordArgModelMap = {};
|
|
91
|
-
for (let i = 0; i < sqlKeywords.length; i++) {
|
|
92
|
-
const word = sqlKeywords[i]; // @@columns
|
|
93
|
-
if (word) {
|
|
94
|
-
const sqlArgModel = await this.generateWord(word, sqlCfgModel);
|
|
95
|
-
if (sqlArgModel) {
|
|
96
|
-
sqlKeywordArgModelMap[word] = sqlArgModel;
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
return sqlKeywordArgModelMap;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
private async generateWord(word: string, sqlCfg: SqlCfgModel): Promise<SqlSegArg> {
|
|
104
|
-
const exeCtx = this.getExecuteContext();
|
|
105
|
-
const reqCfg = exeCtx.getCfgModel();
|
|
106
|
-
const reqModel = exeCtx.getReqModel();
|
|
107
|
-
|
|
108
|
-
if (word === KeysOfCustomSQL.SQL_TABLE) {
|
|
109
|
-
return this.generateTable(reqCfg, sqlCfg);
|
|
110
|
-
} else if (word === KeysOfCustomSQL.SQL_COLUMNS) {
|
|
111
|
-
return this.generateColumns(reqCfg, sqlCfg, reqModel);
|
|
112
|
-
} else if (word.startsWith(KeysOfCustomSQL.SQL_AS_WHERE)) {
|
|
113
|
-
return this.generateCondition(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_WHERE));
|
|
114
|
-
} else if (word === KeysOfCustomSQL.SQL_OFFSET_LIMIT) {
|
|
115
|
-
return this.generateOffsetLimit(reqCfg, sqlCfg, reqModel);
|
|
116
|
-
} else if (word === KeysOfCustomSQL.SQL_ORDER_BYS) {
|
|
117
|
-
return this.generateOrderBys(reqModel, sqlCfg);
|
|
118
|
-
} else if ((
|
|
119
|
-
word.startsWith(KeysOfCustomSQL.SQL_GET_DATA_ATTR_START) ||
|
|
120
|
-
word.startsWith(KeysOfCustomSQL.SQL_GET_CONDITION_ATTR_START)) && word.indexOf('.') > 0) {
|
|
121
|
-
return this.generateGetAttr(reqModel, word); //// data.xxx, condition.xxx
|
|
122
|
-
} else if (word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER) || word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_STRING)) {
|
|
123
|
-
return this.generatePickResAs(reqModel, word); // @@pickResAsNumber:replies_count
|
|
124
|
-
} else if (word.startsWith(KeysOfCustomSQL.SQL_AS_UPDATE)) {
|
|
125
|
-
return this.generateDataUpdate(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_UPDATE));
|
|
126
|
-
} else if (word.startsWith(KeysOfCustomSQL.SQL_AS_INSERT_KEYS)) {
|
|
127
|
-
return this.generateDataAsInsertKeys(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_INSERT_KEYS));
|
|
128
|
-
} else if (word.startsWith(KeysOfCustomSQL.SQL_AS_INSERT_VALUES)) {
|
|
129
|
-
return this.generateDataAsInsertValues(reqModel, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_INSERT_VALUES));
|
|
130
|
-
} else if (word.startsWith(KeysOfCustomSQL.SQL_FUNCTION)) {
|
|
131
|
-
return this.generateSqlJavaFunction(reqCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_FUNCTION));
|
|
132
|
-
} else {
|
|
133
|
-
return new SqlSegArg(word.toString());
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
private generateDataAsInsertKeys(req: RequestModel, sqlCfgModel: SqlCfgModel, dataName: string): SqlSegArg {
|
|
138
|
-
const data = req.getCondOrDataJsonObject(dataName);
|
|
139
|
-
|
|
140
|
-
if (MixinUtils.isEmpty(data)) {
|
|
141
|
-
throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_KEYS, dataName);
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
const keys = Object.keys(data).sort();
|
|
145
|
-
|
|
146
|
-
const columnList = keys.map(columnName => {
|
|
147
|
-
return toSqlColumnName(columnName, sqlCfgModel);
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
const sql = columnList.join(','); // `column1`,`column2`,`column3`,
|
|
151
|
-
return new SqlSegArg(sql); // 只有sql,没有arg
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
private generateTable(requestCfg: RequestCfgModel, sqlCfgModel: SqlCfgModel): SqlSegArg {
|
|
155
|
-
const sqlTableName = ModelUtils.getSqlTable(sqlCfgModel, requestCfg);
|
|
156
|
-
|
|
157
|
-
if (MixinUtils.isEmpty(sqlTableName)) {
|
|
158
|
-
throw new CommonException(Exceptions.CFG_EMPTY_TABLE_NAME);
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
const sqlSchema = ModelUtils.getSqlSchema(sqlCfgModel, requestCfg);
|
|
162
|
-
if (MixinUtils.isNotEmpty(sqlSchema)) {
|
|
163
|
-
return new SqlSegArg(`${toSqlColumnName(sqlSchema, sqlCfgModel)}.${toSqlColumnName(sqlTableName, sqlCfgModel)}`);
|
|
164
|
-
}
|
|
165
|
-
return new SqlSegArg(toSqlColumnName(sqlTableName, sqlCfgModel));
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
private async generateColumns(cfg: RequestCfgModel, sqlCfgModel: SqlCfgModel, req: RequestModel): Promise<SqlSegArg> {
|
|
169
|
-
// req 和 cfg 都没有 columns字段
|
|
170
|
-
if (MixinUtils.isEmpty(cfg.columns) && MixinUtils.isEmpty(req.columns)) {
|
|
171
|
-
return new SqlSegArg('*');
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
const cfgColumns = await this.generateCfgColumns(sqlCfgModel); // 不会为空
|
|
175
|
-
const reqColumns = req.columns;
|
|
176
|
-
|
|
177
|
-
// req 为空
|
|
178
|
-
if (MixinUtils.isEmpty(reqColumns)) {
|
|
179
|
-
return new SqlSegArg(toSqlColumnNamesJoin(cfgColumns, sqlCfgModel));
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
// req 不为空:1. 排除法
|
|
183
|
-
// cfgColumns与reqColumns 都不为空: 使用排除法
|
|
184
|
-
if (isAnyStartWithExclude(reqColumns)) {
|
|
185
|
-
const result = [];
|
|
186
|
-
for (let i = 0; i < cfgColumns.length; i++) {
|
|
187
|
-
const cfgColumn = cfgColumns[i];
|
|
188
|
-
if (reqColumns.indexOf('!' + cfgColumn) < 0) {
|
|
189
|
-
result.push(cfgColumn);
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
return new SqlSegArg(toSqlColumnNamesJoin(result, sqlCfgModel));
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
// req 不为空:2. 取交集
|
|
196
|
-
const result = [];
|
|
197
|
-
for (let i = 0; i < reqColumns.length; i++) {
|
|
198
|
-
const reqColumn = reqColumns[i];
|
|
199
|
-
if (cfgColumns.indexOf(reqColumn) >= 0) {
|
|
200
|
-
result.push(reqColumn);
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
return new SqlSegArg(toSqlColumnNamesJoin(result,sqlCfgModel));
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
/**
|
|
207
|
-
* 生成查询条件
|
|
208
|
-
* @param req
|
|
209
|
-
* @param sqlCfg
|
|
210
|
-
* @param conditionName
|
|
211
|
-
* @private
|
|
212
|
-
*/
|
|
213
|
-
private generateCondition(req: RequestModel, sqlCfg: SqlCfgModel, conditionName: any): SqlSegArg {
|
|
214
|
-
if (MixinUtils.isEmpty(conditionName)) {
|
|
215
|
-
conditionName = 'condition';
|
|
216
|
-
}
|
|
217
|
-
const condition = req.getCondOrDataJsonObject(conditionName);
|
|
218
|
-
|
|
219
|
-
const ss = new CrudProGenSqlCondition(sqlCfg);
|
|
220
|
-
|
|
221
|
-
return ss.generateCondition(condition);
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
private generateOffsetLimit(requestCfg: RequestCfgModel, sqlCfg: SqlCfgModel, req: RequestModel): SqlSegArg {
|
|
225
|
-
const maxLimit = ModelUtils.getMaxLimit(sqlCfg, requestCfg);
|
|
226
|
-
const reqLimit = req.limit;
|
|
227
|
-
const limit = Math.min(maxLimit, reqLimit);
|
|
228
|
-
|
|
229
|
-
if (sqlCfg.sqlDdType === SqlDbType.postgres) {
|
|
230
|
-
return new SqlSegArg(' LIMIT ? OFFSET ? ', [limit, req.offset]);
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
if (sqlCfg.sqlDdType === SqlDbType.sqlserver) {
|
|
234
|
-
return new SqlSegArg(' OFFSET ? ROWS FETCH NEXT ? ROWS ONLY ', [ req.offset, limit]);
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
return new SqlSegArg(' limit ?,? ', [req.offset, limit]);
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
// 生成排序条件
|
|
241
|
-
private generateOrderBys(req: RequestModel, sqlCfgModel: SqlCfgModel): SqlSegArg {
|
|
242
|
-
const orderBys = req.orderBys;
|
|
243
|
-
if (MixinUtils.isEmpty(orderBys)) {
|
|
244
|
-
return null;
|
|
245
|
-
}
|
|
246
|
-
const orderByArr = orderBys.map(orderBy => {
|
|
247
|
-
return toSqlColumnName(orderBy.fieldName, sqlCfgModel) + ' ' + orderBy.orderType;
|
|
248
|
-
});
|
|
249
|
-
const sql = 'order by ' + orderByArr.join(',');
|
|
250
|
-
return new SqlSegArg(sql);
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
private generatePickResAs(req: RequestModel, world: string): SqlSegArg {
|
|
255
|
-
return new SqlSegArg(' ? ', [{
|
|
256
|
-
___GENERATE_GET_RES_ATTR___: world,
|
|
257
|
-
}]);
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
private generateGetAttr(req: RequestModel, word: string): SqlSegArg {
|
|
261
|
-
const attrName = MixinUtils.removeStringPrefix(word, '@@');
|
|
262
|
-
|
|
263
|
-
if (MixinUtils.isEmpty(attrName)) {
|
|
264
|
-
throw new CommonException(Exceptions.CFG_GET_ATTR_NAME_EMPTY, word);
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
const dataValue = req.getJsonObjectValue(attrName);
|
|
268
|
-
|
|
269
|
-
if (typeof dataValue === 'undefined' || !TypeUtils.isBasicType(dataValue)) {
|
|
270
|
-
throw new CommonException(Exceptions.CFG_GET_ATTR_VALUE_ERROR, word);
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
return new SqlSegArg(' ? ', [dataValue]);
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
private generateDataUpdate(req: RequestModel, sqlCfgModel: SqlCfgModel, dataName: string): SqlSegArg {
|
|
277
|
-
const data = req.getCondOrDataJsonObject(dataName);
|
|
278
|
-
|
|
279
|
-
if (MixinUtils.isEmpty(data)) {
|
|
280
|
-
throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_UPDATE, dataName);
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
const keys = Object.keys(data).sort();
|
|
284
|
-
|
|
285
|
-
const sqlList = [];
|
|
286
|
-
const argList = [];
|
|
287
|
-
|
|
288
|
-
for (let i = 0; i < keys.length; i++) {
|
|
289
|
-
const key = keys[i];
|
|
290
|
-
const arg = data[key];
|
|
291
|
-
if (sqlFuncUtils.isSqlFuncArg(arg)) {
|
|
292
|
-
const funcSQL = sqlFuncUtils.toFuncSQL(arg);
|
|
293
|
-
sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ' + funcSQL);
|
|
294
|
-
} else {
|
|
295
|
-
sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ?');
|
|
296
|
-
argList.push(arg);
|
|
297
|
-
}
|
|
298
|
-
}
|
|
299
|
-
|
|
300
|
-
const sql = sqlList.join(',');
|
|
301
|
-
return new SqlSegArg(sql, argList);
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
private generateDataAsInsertValues(req: RequestModel, dataName: string): SqlSegArg {
|
|
305
|
-
const data = req.getCondOrDataJsonObject(dataName);
|
|
306
|
-
|
|
307
|
-
if (MixinUtils.isEmpty(data)) {
|
|
308
|
-
throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_VALUES, dataName);
|
|
309
|
-
}
|
|
310
|
-
|
|
311
|
-
const keys = Object.keys(data).sort();
|
|
312
|
-
|
|
313
|
-
const sqlList = [];
|
|
314
|
-
const argList = [];
|
|
315
|
-
|
|
316
|
-
for (let i = 0; i < keys.length; i++) {
|
|
317
|
-
const key = keys[i];
|
|
318
|
-
const arg = data[key];
|
|
319
|
-
|
|
320
|
-
// 如 data: {xxxTime: {$byFunc:"NOW()"}}
|
|
321
|
-
if (sqlFuncUtils.isSqlFuncArg(arg)) {
|
|
322
|
-
const funcSQL = sqlFuncUtils.toFuncSQL(arg); // values( ? , ? , NOW() , ?)
|
|
323
|
-
sqlList.push(funcSQL);
|
|
324
|
-
} else {
|
|
325
|
-
sqlList.push('?');
|
|
326
|
-
argList.push(arg);
|
|
327
|
-
}
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
const sql = sqlList.join(','); // "?,?,?,?"
|
|
331
|
-
return new SqlSegArg(sql, argList);
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
private generateSqlJavaFunction(requestCfg: RequestCfgModel, tmpFuncName: string): SqlSegArg {
|
|
335
|
-
const exeCtx = this.getExecuteContext();
|
|
336
|
-
|
|
337
|
-
const functionCfg = requestCfg.functionCfg;
|
|
338
|
-
|
|
339
|
-
if (MixinUtils.isEmpty(functionCfg)) {
|
|
340
|
-
throw new CommonException(Exceptions.CFG_SQL_FUNCTION_EMPTY, tmpFuncName);
|
|
341
|
-
}
|
|
342
|
-
|
|
343
|
-
const tmpFunCfg = functionCfg[tmpFuncName];
|
|
344
|
-
|
|
345
|
-
if (ModelUtils.checkFuncCfgValid(tmpFunCfg)) {
|
|
346
|
-
throw new CommonException(Exceptions.CFG_VALIDATE_CUSTOM_FUNCTION_EMPTY, tmpFuncName);
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
const exeFunCtx = new FuncContext();
|
|
350
|
-
|
|
351
|
-
exeFunCtx.currentValue = null;
|
|
352
|
-
exeFunCtx.reqModel = exeCtx.getReqModel();
|
|
353
|
-
exeFunCtx.resModel = exeCtx.getResModel();
|
|
354
|
-
|
|
355
|
-
const dataValue = this.serviceHub.executeFuncCfg(tmpFunCfg, exeFunCtx);
|
|
356
|
-
|
|
357
|
-
return new SqlSegArg(' ? ', [dataValue]);
|
|
358
|
-
}
|
|
359
|
-
|
|
360
|
-
/**
|
|
361
|
-
* 不会返回空。
|
|
362
|
-
* @param sqlCfgModel
|
|
363
|
-
* @private
|
|
364
|
-
*/
|
|
365
|
-
private async generateCfgColumns(sqlCfgModel: SqlCfgModel): Promise<string[]> {
|
|
366
|
-
const tableMeta = await this.serviceHub.getTableMeta(sqlCfgModel);
|
|
367
|
-
|
|
368
|
-
const tableColumns = tableMeta.tableColumns;
|
|
369
|
-
const cfgColumns = sqlCfgModel.columns || [];
|
|
370
|
-
|
|
371
|
-
// 没有配置: 全量
|
|
372
|
-
if (MixinUtils.isEmpty(cfgColumns)) {
|
|
373
|
-
return tableColumns;
|
|
374
|
-
}
|
|
375
|
-
|
|
376
|
-
// 黑名单:排除法
|
|
377
|
-
if (isAnyStartWithExclude(cfgColumns)) {
|
|
378
|
-
const excludeColumns = cfgColumns.filter(c => {
|
|
379
|
-
return c.startsWith('!');
|
|
380
|
-
});
|
|
381
|
-
const excludeColumnsSet = new Set(excludeColumns);
|
|
382
|
-
const result = [];
|
|
383
|
-
for (let i = 0; i < tableColumns.length; i++) {
|
|
384
|
-
const tableColumn = tableColumns[i];
|
|
385
|
-
if (!excludeColumnsSet.has('!' + tableColumn)) {
|
|
386
|
-
result.push(tableColumn);
|
|
387
|
-
}
|
|
388
|
-
}
|
|
389
|
-
return result;
|
|
390
|
-
}
|
|
391
|
-
|
|
392
|
-
// 白名单
|
|
393
|
-
return cfgColumns;
|
|
394
|
-
}
|
|
395
|
-
}
|
|
396
|
-
|
|
397
|
-
export { CrudProOriginToExecuteSql };
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
import * as _ from 'lodash';
|
|
2
|
-
import { ICurdProServiceHub } from '../models/ServiceHub';
|
|
3
|
-
import {ICrudProCfg, ILogger, IPoolConnectionClient} from '../interfaces';
|
|
4
|
-
import { SqlCfgModel } from '../models/SqlCfgModel';
|
|
5
|
-
import { ExecuteContext } from '../models/ExecuteContext';
|
|
6
|
-
import { MixinUtils } from '../utils/MixinUtils';
|
|
7
|
-
import { TypeUtils } from '../utils/TypeUtils';
|
|
8
|
-
import { CompareUtils } from '../utils/CompareUtils';
|
|
9
|
-
import { DateTimeUtils } from '../utils/DateTimeUtils';
|
|
10
|
-
import { IExecuteContextFunc } from '../models/ExecuteContextFunc';
|
|
11
|
-
import { DEFAULT_MAX_LIMIT } from '../defaultConfigs';
|
|
12
|
-
|
|
13
|
-
function createBuildInExecuteFuncMap() {
|
|
14
|
-
return {
|
|
15
|
-
...DateTimeUtils,
|
|
16
|
-
...CompareUtils,
|
|
17
|
-
...MixinUtils,
|
|
18
|
-
...TypeUtils,
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
interface ExecuteUnsafeQueryCtx {
|
|
23
|
-
tableName: string;
|
|
24
|
-
dbName: string;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const buildInExecuteFuncMap = createBuildInExecuteFuncMap();
|
|
28
|
-
|
|
29
|
-
class CrudProServiceBase {
|
|
30
|
-
protected serviceHub: ICurdProServiceHub;
|
|
31
|
-
|
|
32
|
-
constructor(serviceHub: ICurdProServiceHub) {
|
|
33
|
-
this.serviceHub = serviceHub;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
protected getExecuteContext(): ExecuteContext {
|
|
37
|
-
return this.serviceHub.getExecuteContext();
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
protected getContextFunc(): IExecuteContextFunc {
|
|
41
|
-
return this.getExecuteContext().contextFunc;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
protected get logger(): ILogger {
|
|
45
|
-
return this.getExecuteContext().getLogger();
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
protected async getTxConnectionBySqlCfg(sqlCfgModel: SqlCfgModel): Promise<IPoolConnectionClient> {
|
|
49
|
-
const executeContext = this.getExecuteContext();
|
|
50
|
-
const transaction = executeContext.getTransaction();
|
|
51
|
-
const contextFunc = this.getContextFunc();
|
|
52
|
-
const pool = await contextFunc.getConnectionPool(sqlCfgModel);
|
|
53
|
-
return transaction.getTxConnection(pool);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* 不做任何检验,直接执行SQL,只能CrudPro内部使用,不对外使用
|
|
58
|
-
* @param obj
|
|
59
|
-
* @param sql
|
|
60
|
-
* @param values
|
|
61
|
-
* @protected
|
|
62
|
-
*/
|
|
63
|
-
protected async executeUnsafeQuery(obj: ExecuteUnsafeQueryCtx, sql: string, values?: any) {
|
|
64
|
-
const sqlCfgModel: any = {
|
|
65
|
-
sqlTable: obj.tableName,
|
|
66
|
-
sqlDatabase: obj.dbName,
|
|
67
|
-
columns: [],
|
|
68
|
-
columnsRelation: [],
|
|
69
|
-
maxLimit: DEFAULT_MAX_LIMIT,
|
|
70
|
-
resName: 'executeUnsafeQuery',
|
|
71
|
-
originSql: sql,
|
|
72
|
-
executeSql: sql,
|
|
73
|
-
executeSqlArgs: values,
|
|
74
|
-
crudType: null,
|
|
75
|
-
};
|
|
76
|
-
const connection = await this.getTxConnectionBySqlCfg(sqlCfgModel);
|
|
77
|
-
return await connection.query(sql, values);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
protected getContextCfg(): ICrudProCfg {
|
|
81
|
-
return this.getExecuteContext().getContextCfg();
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
protected getExecuteFunction(funcName: string): any {
|
|
85
|
-
const contextFunc = this.getContextFunc();
|
|
86
|
-
const functionMap = contextFunc.getFunctionMap();
|
|
87
|
-
if (functionMap) {
|
|
88
|
-
const func = _.get(functionMap, funcName);
|
|
89
|
-
if (typeof func === 'function') {
|
|
90
|
-
return func;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
console.log('buildInExecuteFuncMap', Object.keys(buildInExecuteFuncMap));
|
|
94
|
-
return _.get(buildInExecuteFuncMap, funcName);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
export { CrudProServiceBase };
|