midway-fatcms 0.0.1-beta.63 → 0.0.1-beta.65
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/dist/config/config.default.d.ts +3 -3
- package/dist/config/config.default.js +160 -160
- package/dist/config/utils.d.ts +1 -1
- package/dist/config/utils.js +23 -23
- package/dist/configuration.d.ts +7 -7
- package/dist/configuration.js +113 -113
- package/dist/controller/base/BaseApiController.d.ts +37 -37
- package/dist/controller/base/BaseApiController.js +164 -164
- package/dist/controller/gateway/AnyApiGatewayController.d.ts +13 -13
- package/dist/controller/gateway/AnyApiGatewayController.js +55 -55
- package/dist/controller/gateway/AsyncTaskController.d.ts +20 -20
- package/dist/controller/gateway/AsyncTaskController.js +181 -181
- package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
- package/dist/controller/gateway/CrudMtdGatewayController.js +122 -122
- package/dist/controller/gateway/CrudStdGatewayController.d.ts +38 -38
- package/dist/controller/gateway/CrudStdGatewayController.js +129 -129
- package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
- package/dist/controller/gateway/DocGatewayController.js +179 -179
- package/dist/controller/gateway/FileController.d.ts +28 -28
- package/dist/controller/gateway/FileController.js +144 -144
- package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
- package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
- package/dist/controller/gateway/PublicApiController.d.ts +31 -31
- package/dist/controller/gateway/PublicApiController.js +179 -179
- package/dist/controller/gateway/StaticController.d.ts +23 -23
- package/dist/controller/gateway/StaticController.js +286 -286
- package/dist/controller/helpers.controller.d.ts +39 -39
- package/dist/controller/helpers.controller.js +188 -188
- package/dist/controller/home.controller.d.ts +9 -9
- package/dist/controller/home.controller.js +72 -72
- package/dist/controller/manage/AnyApiMangeApi.d.ts +10 -10
- package/dist/controller/manage/AnyApiMangeApi.js +98 -98
- package/dist/controller/manage/AppLogMangeApi.d.ts +10 -10
- package/dist/controller/manage/AppLogMangeApi.js +88 -88
- package/dist/controller/manage/AppMangeApi.d.ts +10 -10
- package/dist/controller/manage/AppMangeApi.js +88 -88
- package/dist/controller/manage/AppPageMangeApi.d.ts +10 -10
- package/dist/controller/manage/AppPageMangeApi.js +87 -87
- package/dist/controller/manage/AppSchemaHistoryApi.d.ts +10 -10
- package/dist/controller/manage/AppSchemaHistoryApi.js +83 -83
- package/dist/controller/manage/CrudMethodsMangeApi.d.ts +10 -10
- package/dist/controller/manage/CrudMethodsMangeApi.js +84 -84
- package/dist/controller/manage/CrudStandardDesignApi.d.ts +46 -46
- package/dist/controller/manage/CrudStandardDesignApi.js +367 -367
- package/dist/controller/manage/DataDictManageApi.d.ts +15 -15
- package/dist/controller/manage/DataDictManageApi.js +133 -133
- package/dist/controller/manage/DeployManageApi.d.ts +19 -19
- package/dist/controller/manage/DeployManageApi.js +180 -180
- package/dist/controller/manage/DocLibManageApi.d.ts +10 -10
- package/dist/controller/manage/DocLibManageApi.js +104 -104
- package/dist/controller/manage/DocManageApi.d.ts +11 -11
- package/dist/controller/manage/DocManageApi.js +130 -130
- package/dist/controller/manage/FileManageApi.d.ts +13 -13
- package/dist/controller/manage/FileManageApi.js +77 -77
- package/dist/controller/manage/LowCodeTplManageApi.d.ts +13 -13
- package/dist/controller/manage/LowCodeTplManageApi.js +86 -86
- package/dist/controller/manage/MenuManageApi.d.ts +10 -10
- package/dist/controller/manage/MenuManageApi.js +93 -93
- package/dist/controller/manage/ProxyApiMangeApi.d.ts +10 -10
- package/dist/controller/manage/ProxyApiMangeApi.js +87 -87
- package/dist/controller/manage/SuperAdminManageApi.d.ts +24 -24
- package/dist/controller/manage/SuperAdminManageApi.js +153 -153
- package/dist/controller/manage/SysConfigMangeApi.d.ts +11 -11
- package/dist/controller/manage/SysConfigMangeApi.js +126 -126
- package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
- package/dist/controller/manage/SystemInfoManageApi.js +72 -72
- package/dist/controller/manage/UserAccountManageApi.d.ts +14 -14
- package/dist/controller/manage/UserAccountManageApi.js +129 -129
- package/dist/controller/manage/WorkbenchMangeApi.d.ts +11 -11
- package/dist/controller/manage/WorkbenchMangeApi.js +103 -103
- package/dist/controller/myinfo/AuthController.d.ts +33 -33
- package/dist/controller/myinfo/AuthController.js +136 -136
- package/dist/controller/myinfo/MyInfoController.d.ts +13 -13
- package/dist/controller/myinfo/MyInfoController.js +51 -51
- package/dist/controller/render/AppRenderController.d.ts +11 -11
- package/dist/controller/render/AppRenderController.js +92 -92
- package/dist/controller/test.controller.d.ts +8 -8
- package/dist/controller/test.controller.js +51 -51
- package/dist/filter/default.filter.d.ts +7 -7
- package/dist/filter/default.filter.js +23 -23
- package/dist/filter/notfound.filter.d.ts +5 -5
- package/dist/filter/notfound.filter.js +20 -20
- package/dist/index.d.ts +103 -103
- package/dist/index.js +121 -121
- package/dist/interface.d.ts +27 -27
- package/dist/interface.js +3 -3
- package/dist/libs/crud-pro/CrudPro.d.ts +37 -37
- package/dist/libs/crud-pro/CrudPro.js +136 -136
- package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
- package/dist/libs/crud-pro/defaultConfigs.js +15 -15
- package/dist/libs/crud-pro/exceptions.d.ts +104 -104
- package/dist/libs/crud-pro/exceptions.js +117 -117
- package/dist/libs/crud-pro/interfaces.d.ts +165 -165
- package/dist/libs/crud-pro/interfaces.js +12 -12
- package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -49
- package/dist/libs/crud-pro/models/ExecuteContext.js +79 -79
- package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -38
- package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -72
- package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
- package/dist/libs/crud-pro/models/FuncContext.js +6 -6
- package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
- package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
- package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
- package/dist/libs/crud-pro/models/RequestModel.js +113 -113
- package/dist/libs/crud-pro/models/ResModel.d.ts +16 -16
- package/dist/libs/crud-pro/models/ResModel.js +2 -2
- package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
- package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
- package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +22 -22
- package/dist/libs/crud-pro/models/SqlCfgModel.js +40 -40
- package/dist/libs/crud-pro/models/SqlSegArg.d.ts +6 -6
- package/dist/libs/crud-pro/models/SqlSegArg.js +12 -12
- package/dist/libs/crud-pro/models/Transaction.d.ts +30 -30
- package/dist/libs/crud-pro/models/Transaction.js +74 -74
- package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +28 -28
- package/dist/libs/crud-pro/models/TransactionMySQL.js +76 -76
- package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +28 -28
- package/dist/libs/crud-pro/models/TransactionPostgres.js +85 -85
- package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +34 -34
- package/dist/libs/crud-pro/models/TransactionSqlServer.js +92 -92
- package/dist/libs/crud-pro/models/keys.d.ts +110 -110
- package/dist/libs/crud-pro/models/keys.js +154 -154
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -11
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -73
- package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
- package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +125 -125
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -225
- package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +9 -9
- package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +51 -51
- package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +13 -13
- package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +148 -148
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +24 -24
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +355 -355
- package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
- package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -165
- package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
- package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +334 -334
- package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -24
- package/dist/libs/crud-pro/services/CrudProServiceBase.js +90 -90
- package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -9
- package/dist/libs/crud-pro/services/CrudProTableMetaService.js +72 -72
- package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +32 -32
- package/dist/libs/crud-pro/services/CurdProServiceHub.js +64 -64
- package/dist/libs/crud-pro/utils/CompareUtils.d.ts +9 -9
- package/dist/libs/crud-pro/utils/CompareUtils.js +25 -25
- package/dist/libs/crud-pro/utils/DatabaseName.d.ts +9 -9
- package/dist/libs/crud-pro/utils/DatabaseName.js +50 -50
- package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +7 -7
- package/dist/libs/crud-pro/utils/DateTimeUtils.js +21 -21
- package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +19 -19
- package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +47 -47
- package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +5 -5
- package/dist/libs/crud-pro/utils/MessageParseUtils.js +33 -33
- package/dist/libs/crud-pro/utils/MixinUtils.d.ts +39 -39
- package/dist/libs/crud-pro/utils/MixinUtils.js +255 -255
- package/dist/libs/crud-pro/utils/ModelUtils.d.ts +11 -11
- package/dist/libs/crud-pro/utils/ModelUtils.js +54 -54
- package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +11 -11
- package/dist/libs/crud-pro/utils/MultiKeyMap.js +63 -63
- package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +5 -5
- package/dist/libs/crud-pro/utils/SqlFuncUtils.js +29 -29
- package/dist/libs/crud-pro/utils/TypeUtils.d.ts +40 -40
- package/dist/libs/crud-pro/utils/TypeUtils.js +166 -166
- package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +3 -3
- package/dist/libs/crud-pro/utils/ValidateUtils.js +165 -165
- package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +3 -3
- package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +19 -19
- package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +3 -3
- package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +20 -20
- package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +3 -3
- package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +20 -20
- package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +4 -4
- package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +21 -21
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -3
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -22
- package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +2 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +11 -11
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +11 -11
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +2 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +128 -128
- package/dist/libs/global-config/global-config.d.ts +69 -69
- package/dist/libs/global-config/global-config.js +36 -36
- package/dist/libs/utils/base64.d.ts +9 -9
- package/dist/libs/utils/base64.js +42 -42
- package/dist/libs/utils/common-dto.d.ts +18 -18
- package/dist/libs/utils/common-dto.js +40 -40
- package/dist/libs/utils/crypto-utils.d.ts +3 -3
- package/dist/libs/utils/crypto-utils.js +46 -46
- package/dist/libs/utils/errorToString.d.ts +2 -2
- package/dist/libs/utils/errorToString.js +57 -57
- package/dist/libs/utils/fatcms-request.d.ts +30 -30
- package/dist/libs/utils/fatcms-request.js +104 -104
- package/dist/libs/utils/functions.d.ts +5 -5
- package/dist/libs/utils/functions.js +72 -72
- package/dist/libs/utils/ordernum-utils.d.ts +2 -2
- package/dist/libs/utils/ordernum-utils.js +13 -13
- package/dist/libs/utils/parseConfig.d.ts +8 -7
- package/dist/libs/utils/parseConfig.js +47 -44
- package/dist/libs/utils/parseCreateSql.d.ts +10 -10
- package/dist/libs/utils/parseCreateSql.js +87 -87
- package/dist/libs/utils/render-utils.d.ts +28 -28
- package/dist/libs/utils/render-utils.js +133 -133
- package/dist/middleware/forbidden.middleware.d.ts +10 -10
- package/dist/middleware/forbidden.middleware.js +54 -54
- package/dist/middleware/global.middleware.d.ts +10 -10
- package/dist/middleware/global.middleware.js +266 -266
- package/dist/middleware/permission.middleware.d.ts +18 -18
- package/dist/middleware/permission.middleware.js +74 -74
- package/dist/middleware/rediscache.middleware.d.ts +3 -3
- package/dist/middleware/rediscache.middleware.js +77 -77
- package/dist/middleware/redislock.middleware.d.ts +7 -7
- package/dist/middleware/redislock.middleware.js +72 -72
- package/dist/middleware/tx.middleware.d.ts +9 -9
- package/dist/middleware/tx.middleware.js +40 -40
- package/dist/models/AsyncTaskModel.d.ts +74 -74
- package/dist/models/AsyncTaskModel.js +31 -31
- package/dist/models/RedisKeys.d.ts +15 -15
- package/dist/models/RedisKeys.js +18 -18
- package/dist/models/SystemEntities.d.ts +105 -105
- package/dist/models/SystemEntities.js +9 -9
- package/dist/models/SystemPerm.d.ts +95 -95
- package/dist/models/SystemPerm.js +100 -100
- package/dist/models/SystemTables.d.ts +25 -25
- package/dist/models/SystemTables.js +28 -28
- package/dist/models/bizmodels.d.ts +104 -99
- package/dist/models/bizmodels.js +39 -39
- package/dist/models/contextLogger.d.ts +25 -25
- package/dist/models/contextLogger.js +112 -112
- package/dist/models/devops.d.ts +12 -12
- package/dist/models/devops.js +19 -19
- package/dist/models/userSession.d.ts +62 -62
- package/dist/models/userSession.js +165 -165
- package/dist/schedule/anonymousContext.d.ts +14 -14
- package/dist/schedule/anonymousContext.js +59 -59
- package/dist/schedule/index.d.ts +4 -4
- package/dist/schedule/index.js +10 -10
- package/dist/schedule/runSchedule.d.ts +12 -12
- package/dist/schedule/runSchedule.js +68 -68
- package/dist/schedule/scheduleNames.d.ts +13 -13
- package/dist/schedule/scheduleNames.js +17 -17
- package/dist/service/AuthService.d.ts +71 -71
- package/dist/service/AuthService.js +263 -259
- package/dist/service/EnumInfoService.d.ts +30 -30
- package/dist/service/EnumInfoService.js +127 -127
- package/dist/service/FileCenterService.d.ts +43 -43
- package/dist/service/FileCenterService.js +351 -351
- package/dist/service/SysConfigService.d.ts +7 -7
- package/dist/service/SysConfigService.js +47 -47
- package/dist/service/UserAccountService.d.ts +23 -23
- package/dist/service/UserAccountService.js +107 -107
- package/dist/service/UserSessionService.d.ts +38 -38
- package/dist/service/UserSessionService.js +157 -157
- package/dist/service/VisitStatService.d.ts +14 -14
- package/dist/service/VisitStatService.js +158 -158
- package/dist/service/WorkbenchService.d.ts +53 -53
- package/dist/service/WorkbenchService.js +211 -211
- package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
- package/dist/service/anyapi/AnyApiSandboxService.js +110 -110
- package/dist/service/anyapi/AnyApiService.d.ts +27 -27
- package/dist/service/anyapi/AnyApiService.js +181 -181
- package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -50
- package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -287
- package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -7
- package/dist/service/asyncTask/AsyncTaskService.js +34 -34
- package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -10
- package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -2
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -7
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -216
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -36
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -141
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -46
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -135
- package/dist/service/base/ApiBaseService.d.ts +15 -15
- package/dist/service/base/ApiBaseService.js +50 -50
- package/dist/service/base/ApiRateLimiter.d.ts +10 -10
- package/dist/service/base/ApiRateLimiter.js +51 -51
- package/dist/service/base/BaseService.d.ts +41 -41
- package/dist/service/base/BaseService.js +101 -101
- package/dist/service/base/RedisCacheService.d.ts +20 -20
- package/dist/service/base/RedisCacheService.js +57 -57
- package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
- package/dist/service/crudstd/CrudStdActionService.js +32 -32
- package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
- package/dist/service/crudstd/CrudStdConstant.js +64 -64
- package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
- package/dist/service/crudstd/CrudStdRelationService.js +121 -121
- package/dist/service/crudstd/CrudStdService.d.ts +70 -69
- package/dist/service/crudstd/CrudStdService.js +403 -392
- package/dist/service/curd/CrudProQuick.d.ts +44 -44
- package/dist/service/curd/CrudProQuick.js +147 -147
- package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
- package/dist/service/curd/CurdMixByAccountService.js +113 -113
- package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
- package/dist/service/curd/CurdMixByDictService.js +114 -114
- package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -31
- package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -203
- package/dist/service/curd/CurdMixBySysConfigService.d.ts +9 -9
- package/dist/service/curd/CurdMixBySysConfigService.js +80 -80
- package/dist/service/curd/CurdMixByWorkbenchService.d.ts +10 -10
- package/dist/service/curd/CurdMixByWorkbenchService.js +78 -78
- package/dist/service/curd/CurdMixService.d.ts +28 -28
- package/dist/service/curd/CurdMixService.js +100 -100
- package/dist/service/curd/CurdMixUtils.d.ts +57 -57
- package/dist/service/curd/CurdMixUtils.js +331 -331
- package/dist/service/curd/CurdProService.d.ts +32 -32
- package/dist/service/curd/CurdProService.js +212 -212
- package/dist/service/curd/fixCfgModel.d.ts +3 -3
- package/dist/service/curd/fixCfgModel.js +104 -104
- package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
- package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
- package/dist/service/proxyapi/ProxyApiService.d.ts +61 -61
- package/dist/service/proxyapi/ProxyApiService.js +294 -294
- package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
- package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
- package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
- package/dist/service/proxyapi/RouteHandler.js +9 -9
- package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
- package/dist/service/proxyapi/RouteTrie.js +63 -63
- package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
- package/dist/service/proxyapi/WeightedRandom.js +31 -31
- package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
- package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
- package/index.d.ts +10 -10
- package/package.json +87 -87
- package/src/controller/manage/DocLibManageApi.ts +5 -5
- package/src/controller/manage/FileManageApi.ts +5 -5
- package/src/controller/manage/MenuManageApi.ts +4 -4
- package/src/libs/utils/parseConfig.ts +4 -0
- package/src/models/bizmodels.ts +8 -2
- package/src/service/AuthService.ts +6 -1
- package/src/service/EnumInfoService.ts +1 -1
- package/src/service/crudstd/CrudStdService.ts +15 -2
- package/src/service/proxyapi/WeightedRandom.ts +1 -1
- package/src/service/proxyapi/WeightedRoundRobin.ts +1 -1
- package/tsconfig.json +32 -32
|
@@ -1,267 +1,267 @@
|
|
|
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.CrudStandardDesignApi = void 0;
|
|
13
|
-
const core_1 = require("@midwayjs/core");
|
|
14
|
-
const BaseApiController_1 = require("../base/BaseApiController");
|
|
15
|
-
const parseCreateSql_1 = require("../../libs/utils/parseCreateSql");
|
|
16
|
-
const permission_middleware_1 = require("../../middleware/permission.middleware");
|
|
17
|
-
const SystemPerm_1 = require("../../models/SystemPerm");
|
|
18
|
-
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
19
|
-
const SystemTables_1 = require("../../models/SystemTables");
|
|
20
|
-
const exceptions_1 = require("../../libs/crud-pro/exceptions");
|
|
21
|
-
const DatabaseName_1 = require("../../libs/crud-pro/utils/DatabaseName");
|
|
22
|
-
const common_dto_1 = require("../../libs/utils/common-dto");
|
|
23
|
-
function getObjectKeysWithValue(obj) {
|
|
24
|
-
const keys = Object.keys(obj || {});
|
|
25
|
-
return keys.filter((key) => {
|
|
26
|
-
const valueObj = obj[key];
|
|
27
|
-
const valueKeys = Object.keys(valueObj || {});
|
|
28
|
-
return valueKeys.length > 0;
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiController_1.BaseApiController {
|
|
32
|
-
async getDataBaseList() {
|
|
33
|
-
const mysqlList = getObjectKeysWithValue(this.mysql2Config);
|
|
34
|
-
const postgresList = getObjectKeysWithValue(this.postgres2Config);
|
|
35
|
-
const sqlServerList = getObjectKeysWithValue(this.sqlserver2Config);
|
|
36
|
-
const toSelectList = (dbCfgNameList, dbType) => {
|
|
37
|
-
return dbCfgNameList.map(dbName => {
|
|
38
|
-
const value = (0, DatabaseName_1.toDatabaseNameStr)(dbType, dbName);
|
|
39
|
-
return { value, label: value, dbName, dbType };
|
|
40
|
-
});
|
|
41
|
-
};
|
|
42
|
-
const mysqlObjList = toSelectList(mysqlList, keys_1.SqlDbType.mysql);
|
|
43
|
-
const postgresObjList = toSelectList(postgresList, keys_1.SqlDbType.postgres);
|
|
44
|
-
const sqlserverObjList = toSelectList(sqlServerList, keys_1.SqlDbType.sqlserver);
|
|
45
|
-
const databaseList = [...mysqlObjList, ...postgresObjList, ...sqlserverObjList].filter((obj) => {
|
|
46
|
-
const value = '' + obj.value;
|
|
47
|
-
return !value.endsWith('_fatcms_inner_demo_config');
|
|
48
|
-
});
|
|
49
|
-
return {
|
|
50
|
-
success: true,
|
|
51
|
-
data: databaseList,
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
async getTableList() {
|
|
55
|
-
const { databaseName } = this.ctx.request.body;
|
|
56
|
-
const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
|
|
57
|
-
if (dbType === keys_1.SqlDbType.postgres) {
|
|
58
|
-
return this.getTableListOfPostgreSQL(dbName);
|
|
59
|
-
}
|
|
60
|
-
if (dbType === keys_1.SqlDbType.sqlserver) {
|
|
61
|
-
return this.getTableListOfSqlserver(dbName);
|
|
62
|
-
}
|
|
63
|
-
const res = await this.curdMixService.executeSQL({
|
|
64
|
-
executeSql: 'SHOW TABLES',
|
|
65
|
-
sqlDatabase: dbName,
|
|
66
|
-
sqlDbType: keys_1.SqlDbType.mysql,
|
|
67
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
68
|
-
});
|
|
69
|
-
const arr = JSON.parse(JSON.stringify(res));
|
|
70
|
-
const tableNames = arr.map(a => {
|
|
71
|
-
const v = Object.values(a);
|
|
72
|
-
const tableName = v[0];
|
|
73
|
-
return {
|
|
74
|
-
value: tableName,
|
|
75
|
-
label: tableName,
|
|
76
|
-
dbName,
|
|
77
|
-
dbType,
|
|
78
|
-
tableName,
|
|
79
|
-
};
|
|
80
|
-
});
|
|
81
|
-
return common_dto_1.CommonResult.successRes(tableNames);
|
|
82
|
-
}
|
|
83
|
-
async getTableFields() {
|
|
84
|
-
const { databaseName, tableName } = this.ctx.request.body;
|
|
85
|
-
const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
|
|
86
|
-
if (dbType === keys_1.SqlDbType.postgres) {
|
|
87
|
-
return this.getTableFieldsOfPostgreSQL(dbName, tableName);
|
|
88
|
-
}
|
|
89
|
-
if (dbType === keys_1.SqlDbType.sqlserver) {
|
|
90
|
-
return this.getTableFieldsOfSqlServer(dbName, tableName);
|
|
91
|
-
}
|
|
92
|
-
const tableDescribe = await this.curdMixService.executeSQL({
|
|
93
|
-
executeSql: 'describe ' + tableName,
|
|
94
|
-
sqlDatabase: dbName,
|
|
95
|
-
sqlDbType: keys_1.SqlDbType.mysql,
|
|
96
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
97
|
-
});
|
|
98
|
-
const tableCreate = await this.curdMixService.executeSQL({
|
|
99
|
-
executeSql: 'show create table ' + tableName,
|
|
100
|
-
sqlDatabase: dbName,
|
|
101
|
-
sqlDbType: keys_1.SqlDbType.mysql,
|
|
102
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
103
|
-
});
|
|
104
|
-
const tableCreateStr = tableCreate[0]['Create Table'];
|
|
105
|
-
const { fieldsTitleMap, tableTitle } = (0, parseCreateSql_1.parseCreateSqlToTitleMap)(tableCreateStr);
|
|
106
|
-
const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
|
|
107
|
-
const fields = tableDescribe2.map(fieldObj => {
|
|
108
|
-
const { Default, Extra, Field, Key, Null, Type } = fieldObj;
|
|
109
|
-
const fieldTitle = fieldsTitleMap[Field];
|
|
110
|
-
return {
|
|
111
|
-
fieldIndex: Field || '',
|
|
112
|
-
fieldTitle: fieldTitle || Field || '',
|
|
113
|
-
isNullable: Null,
|
|
114
|
-
defaultValue: Default,
|
|
115
|
-
extra: Extra,
|
|
116
|
-
key: Key,
|
|
117
|
-
type: Type,
|
|
118
|
-
};
|
|
119
|
-
});
|
|
120
|
-
return {
|
|
121
|
-
success: true,
|
|
122
|
-
data: {
|
|
123
|
-
fields,
|
|
124
|
-
tableName,
|
|
125
|
-
tableTitle,
|
|
126
|
-
},
|
|
127
|
-
};
|
|
128
|
-
}
|
|
129
|
-
/**
|
|
130
|
-
* 获取角色列表
|
|
131
|
-
*/
|
|
132
|
-
async getRoleOptionsList() {
|
|
133
|
-
return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_role, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
|
|
134
|
-
}
|
|
135
|
-
/**
|
|
136
|
-
* 获取功能点列表
|
|
137
|
-
*/
|
|
138
|
-
async getFuncOptionsList() {
|
|
139
|
-
return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_func, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
|
|
140
|
-
}
|
|
141
|
-
async getTableListOfSqlserver(dbName) {
|
|
142
|
-
const dbConfig = this.sqlserver2Config[dbName];
|
|
143
|
-
if (!dbConfig) {
|
|
144
|
-
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
145
|
-
}
|
|
146
|
-
const dbType = keys_1.SqlDbType.sqlserver;
|
|
147
|
-
const sql = 'SELECT name as tablename FROM sys.tables';
|
|
148
|
-
const arr = await this.curdMixService.executeSQL({
|
|
149
|
-
executeSql: sql,
|
|
150
|
-
sqlDatabase: dbName,
|
|
151
|
-
sqlDbType: dbType,
|
|
152
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
153
|
-
executeSqlArgs: [],
|
|
154
|
-
});
|
|
155
|
-
const tableNames = arr.map(v => {
|
|
156
|
-
const tableName = v.tablename;
|
|
157
|
-
return {
|
|
158
|
-
value: tableName,
|
|
159
|
-
label: tableName,
|
|
160
|
-
dbName,
|
|
161
|
-
dbType,
|
|
162
|
-
tableName,
|
|
163
|
-
};
|
|
164
|
-
});
|
|
165
|
-
return common_dto_1.CommonResult.successRes(tableNames);
|
|
166
|
-
}
|
|
167
|
-
async getTableListOfPostgreSQL(dbName) {
|
|
168
|
-
const dbConfig = this.postgres2Config[dbName];
|
|
169
|
-
if (!dbConfig) {
|
|
170
|
-
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
171
|
-
}
|
|
172
|
-
const dbType = keys_1.SqlDbType.postgres;
|
|
173
|
-
const schemaname = 'public';
|
|
174
|
-
const tableListSql = '' + 'SELECT tablename\n' + 'FROM pg_tables\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY tablename;';
|
|
175
|
-
const viewListSql = '' + 'SELECT viewname as tablename\n' + 'FROM pg_views\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY viewname;';
|
|
176
|
-
const toSelectOptions = async (executeSql, tableType) => {
|
|
177
|
-
const arr = await this.curdMixService.executeSQL({
|
|
178
|
-
executeSql: executeSql,
|
|
179
|
-
sqlDatabase: dbName,
|
|
180
|
-
sqlDbType: dbType,
|
|
181
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
182
|
-
executeSqlArgs: [],
|
|
183
|
-
});
|
|
184
|
-
return arr.map(v => {
|
|
185
|
-
const tableName = v.tablename;
|
|
186
|
-
return {
|
|
187
|
-
value: tableName,
|
|
188
|
-
label: tableName,
|
|
189
|
-
dbName,
|
|
190
|
-
dbType,
|
|
191
|
-
tableName,
|
|
192
|
-
tableType,
|
|
193
|
-
};
|
|
194
|
-
});
|
|
195
|
-
};
|
|
196
|
-
const tableNames = await toSelectOptions(tableListSql, 'table');
|
|
197
|
-
const viewNames = await toSelectOptions(viewListSql, 'view');
|
|
198
|
-
const tableNameMerge = [...tableNames, ...viewNames];
|
|
199
|
-
return common_dto_1.CommonResult.successRes(tableNameMerge);
|
|
200
|
-
}
|
|
201
|
-
async getTableFieldsOfSqlServer(dbName, tableName) {
|
|
202
|
-
const dbConfig = this.sqlserver2Config[dbName];
|
|
203
|
-
if (!dbConfig) {
|
|
204
|
-
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
205
|
-
}
|
|
206
|
-
const columnArraySql = '' +
|
|
207
|
-
'SELECT\n' +
|
|
208
|
-
' c.name AS column_name,\n' +
|
|
209
|
-
' t.name AS data_type,\n' +
|
|
210
|
-
' c.max_length AS max_length,\n' +
|
|
211
|
-
' c.precision,\n' +
|
|
212
|
-
' c.scale,\n' +
|
|
213
|
-
' c.is_nullable,\n' +
|
|
214
|
-
' c.is_identity,\n' +
|
|
215
|
-
' dc.definition AS column_default, \n' +
|
|
216
|
-
' ep.value AS column_description \n' +
|
|
217
|
-
'FROM\n' +
|
|
218
|
-
' sys.columns c\n' +
|
|
219
|
-
' JOIN\n' +
|
|
220
|
-
' sys.types t ON c.user_type_id = t.user_type_id\n' +
|
|
221
|
-
' LEFT JOIN\n' +
|
|
222
|
-
' sys.default_constraints dc\n' +
|
|
223
|
-
' ON c.default_object_id = dc.object_id \n' +
|
|
224
|
-
' LEFT JOIN\n' +
|
|
225
|
-
' sys.extended_properties ep\n' +
|
|
226
|
-
' ON c.object_id = ep.major_id\n' +
|
|
227
|
-
' AND c.column_id = ep.minor_id\n' +
|
|
228
|
-
'WHERE\n' +
|
|
229
|
-
` c.object_id = OBJECT_ID('${tableName}') \n` +
|
|
230
|
-
' ORDER BY\n' +
|
|
231
|
-
' c.column_id;';
|
|
232
|
-
const dbType = keys_1.SqlDbType.sqlserver;
|
|
233
|
-
const columnArray = await this.curdMixService.executeSQL({
|
|
234
|
-
executeSql: columnArraySql,
|
|
235
|
-
sqlDatabase: dbName,
|
|
236
|
-
sqlDbType: dbType,
|
|
237
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
238
|
-
executeSqlArgs: [],
|
|
239
|
-
});
|
|
240
|
-
const fields = columnArray.map(columnObj => {
|
|
241
|
-
const { column_name, is_nullable, column_default, data_type, is_identity, column_description, ...others } = columnObj;
|
|
242
|
-
return {
|
|
243
|
-
fieldIndex: column_name || '',
|
|
244
|
-
fieldTitle: column_description || column_name || '',
|
|
245
|
-
isNullable: is_nullable,
|
|
246
|
-
defaultValue: column_default || '',
|
|
247
|
-
extra: others,
|
|
248
|
-
// key: column_name, // 索引
|
|
249
|
-
type: data_type,
|
|
250
|
-
is_identity: is_identity,
|
|
251
|
-
};
|
|
252
|
-
});
|
|
253
|
-
return common_dto_1.CommonResult.successRes({
|
|
254
|
-
fields,
|
|
255
|
-
tableName,
|
|
256
|
-
tableTitle: tableName,
|
|
257
|
-
});
|
|
258
|
-
}
|
|
259
|
-
async getTableFieldsOfPostgreSQL(dbName, tableName) {
|
|
260
|
-
const dbConfig = this.postgres2Config[dbName];
|
|
261
|
-
if (!dbConfig) {
|
|
262
|
-
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
263
|
-
}
|
|
264
|
-
const schemaname = 'public';
|
|
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.CrudStandardDesignApi = void 0;
|
|
13
|
+
const core_1 = require("@midwayjs/core");
|
|
14
|
+
const BaseApiController_1 = require("../base/BaseApiController");
|
|
15
|
+
const parseCreateSql_1 = require("../../libs/utils/parseCreateSql");
|
|
16
|
+
const permission_middleware_1 = require("../../middleware/permission.middleware");
|
|
17
|
+
const SystemPerm_1 = require("../../models/SystemPerm");
|
|
18
|
+
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
19
|
+
const SystemTables_1 = require("../../models/SystemTables");
|
|
20
|
+
const exceptions_1 = require("../../libs/crud-pro/exceptions");
|
|
21
|
+
const DatabaseName_1 = require("../../libs/crud-pro/utils/DatabaseName");
|
|
22
|
+
const common_dto_1 = require("../../libs/utils/common-dto");
|
|
23
|
+
function getObjectKeysWithValue(obj) {
|
|
24
|
+
const keys = Object.keys(obj || {});
|
|
25
|
+
return keys.filter((key) => {
|
|
26
|
+
const valueObj = obj[key];
|
|
27
|
+
const valueKeys = Object.keys(valueObj || {});
|
|
28
|
+
return valueKeys.length > 0;
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiController_1.BaseApiController {
|
|
32
|
+
async getDataBaseList() {
|
|
33
|
+
const mysqlList = getObjectKeysWithValue(this.mysql2Config);
|
|
34
|
+
const postgresList = getObjectKeysWithValue(this.postgres2Config);
|
|
35
|
+
const sqlServerList = getObjectKeysWithValue(this.sqlserver2Config);
|
|
36
|
+
const toSelectList = (dbCfgNameList, dbType) => {
|
|
37
|
+
return dbCfgNameList.map(dbName => {
|
|
38
|
+
const value = (0, DatabaseName_1.toDatabaseNameStr)(dbType, dbName);
|
|
39
|
+
return { value, label: value, dbName, dbType };
|
|
40
|
+
});
|
|
41
|
+
};
|
|
42
|
+
const mysqlObjList = toSelectList(mysqlList, keys_1.SqlDbType.mysql);
|
|
43
|
+
const postgresObjList = toSelectList(postgresList, keys_1.SqlDbType.postgres);
|
|
44
|
+
const sqlserverObjList = toSelectList(sqlServerList, keys_1.SqlDbType.sqlserver);
|
|
45
|
+
const databaseList = [...mysqlObjList, ...postgresObjList, ...sqlserverObjList].filter((obj) => {
|
|
46
|
+
const value = '' + obj.value;
|
|
47
|
+
return !value.endsWith('_fatcms_inner_demo_config');
|
|
48
|
+
});
|
|
49
|
+
return {
|
|
50
|
+
success: true,
|
|
51
|
+
data: databaseList,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
async getTableList() {
|
|
55
|
+
const { databaseName } = this.ctx.request.body;
|
|
56
|
+
const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
|
|
57
|
+
if (dbType === keys_1.SqlDbType.postgres) {
|
|
58
|
+
return this.getTableListOfPostgreSQL(dbName);
|
|
59
|
+
}
|
|
60
|
+
if (dbType === keys_1.SqlDbType.sqlserver) {
|
|
61
|
+
return this.getTableListOfSqlserver(dbName);
|
|
62
|
+
}
|
|
63
|
+
const res = await this.curdMixService.executeSQL({
|
|
64
|
+
executeSql: 'SHOW TABLES',
|
|
65
|
+
sqlDatabase: dbName,
|
|
66
|
+
sqlDbType: keys_1.SqlDbType.mysql,
|
|
67
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
68
|
+
});
|
|
69
|
+
const arr = JSON.parse(JSON.stringify(res));
|
|
70
|
+
const tableNames = arr.map(a => {
|
|
71
|
+
const v = Object.values(a);
|
|
72
|
+
const tableName = v[0];
|
|
73
|
+
return {
|
|
74
|
+
value: tableName,
|
|
75
|
+
label: tableName,
|
|
76
|
+
dbName,
|
|
77
|
+
dbType,
|
|
78
|
+
tableName,
|
|
79
|
+
};
|
|
80
|
+
});
|
|
81
|
+
return common_dto_1.CommonResult.successRes(tableNames);
|
|
82
|
+
}
|
|
83
|
+
async getTableFields() {
|
|
84
|
+
const { databaseName, tableName } = this.ctx.request.body;
|
|
85
|
+
const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
|
|
86
|
+
if (dbType === keys_1.SqlDbType.postgres) {
|
|
87
|
+
return this.getTableFieldsOfPostgreSQL(dbName, tableName);
|
|
88
|
+
}
|
|
89
|
+
if (dbType === keys_1.SqlDbType.sqlserver) {
|
|
90
|
+
return this.getTableFieldsOfSqlServer(dbName, tableName);
|
|
91
|
+
}
|
|
92
|
+
const tableDescribe = await this.curdMixService.executeSQL({
|
|
93
|
+
executeSql: 'describe ' + tableName,
|
|
94
|
+
sqlDatabase: dbName,
|
|
95
|
+
sqlDbType: keys_1.SqlDbType.mysql,
|
|
96
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
97
|
+
});
|
|
98
|
+
const tableCreate = await this.curdMixService.executeSQL({
|
|
99
|
+
executeSql: 'show create table ' + tableName,
|
|
100
|
+
sqlDatabase: dbName,
|
|
101
|
+
sqlDbType: keys_1.SqlDbType.mysql,
|
|
102
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
103
|
+
});
|
|
104
|
+
const tableCreateStr = tableCreate[0]['Create Table'];
|
|
105
|
+
const { fieldsTitleMap, tableTitle } = (0, parseCreateSql_1.parseCreateSqlToTitleMap)(tableCreateStr);
|
|
106
|
+
const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
|
|
107
|
+
const fields = tableDescribe2.map(fieldObj => {
|
|
108
|
+
const { Default, Extra, Field, Key, Null, Type } = fieldObj;
|
|
109
|
+
const fieldTitle = fieldsTitleMap[Field];
|
|
110
|
+
return {
|
|
111
|
+
fieldIndex: Field || '',
|
|
112
|
+
fieldTitle: fieldTitle || Field || '',
|
|
113
|
+
isNullable: Null,
|
|
114
|
+
defaultValue: Default,
|
|
115
|
+
extra: Extra,
|
|
116
|
+
key: Key,
|
|
117
|
+
type: Type,
|
|
118
|
+
};
|
|
119
|
+
});
|
|
120
|
+
return {
|
|
121
|
+
success: true,
|
|
122
|
+
data: {
|
|
123
|
+
fields,
|
|
124
|
+
tableName,
|
|
125
|
+
tableTitle,
|
|
126
|
+
},
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* 获取角色列表
|
|
131
|
+
*/
|
|
132
|
+
async getRoleOptionsList() {
|
|
133
|
+
return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_role, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* 获取功能点列表
|
|
137
|
+
*/
|
|
138
|
+
async getFuncOptionsList() {
|
|
139
|
+
return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_func, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
|
|
140
|
+
}
|
|
141
|
+
async getTableListOfSqlserver(dbName) {
|
|
142
|
+
const dbConfig = this.sqlserver2Config[dbName];
|
|
143
|
+
if (!dbConfig) {
|
|
144
|
+
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
145
|
+
}
|
|
146
|
+
const dbType = keys_1.SqlDbType.sqlserver;
|
|
147
|
+
const sql = 'SELECT name as tablename FROM sys.tables';
|
|
148
|
+
const arr = await this.curdMixService.executeSQL({
|
|
149
|
+
executeSql: sql,
|
|
150
|
+
sqlDatabase: dbName,
|
|
151
|
+
sqlDbType: dbType,
|
|
152
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
153
|
+
executeSqlArgs: [],
|
|
154
|
+
});
|
|
155
|
+
const tableNames = arr.map(v => {
|
|
156
|
+
const tableName = v.tablename;
|
|
157
|
+
return {
|
|
158
|
+
value: tableName,
|
|
159
|
+
label: tableName,
|
|
160
|
+
dbName,
|
|
161
|
+
dbType,
|
|
162
|
+
tableName,
|
|
163
|
+
};
|
|
164
|
+
});
|
|
165
|
+
return common_dto_1.CommonResult.successRes(tableNames);
|
|
166
|
+
}
|
|
167
|
+
async getTableListOfPostgreSQL(dbName) {
|
|
168
|
+
const dbConfig = this.postgres2Config[dbName];
|
|
169
|
+
if (!dbConfig) {
|
|
170
|
+
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
171
|
+
}
|
|
172
|
+
const dbType = keys_1.SqlDbType.postgres;
|
|
173
|
+
const schemaname = 'public';
|
|
174
|
+
const tableListSql = '' + 'SELECT tablename\n' + 'FROM pg_tables\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY tablename;';
|
|
175
|
+
const viewListSql = '' + 'SELECT viewname as tablename\n' + 'FROM pg_views\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY viewname;';
|
|
176
|
+
const toSelectOptions = async (executeSql, tableType) => {
|
|
177
|
+
const arr = await this.curdMixService.executeSQL({
|
|
178
|
+
executeSql: executeSql,
|
|
179
|
+
sqlDatabase: dbName,
|
|
180
|
+
sqlDbType: dbType,
|
|
181
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
182
|
+
executeSqlArgs: [],
|
|
183
|
+
});
|
|
184
|
+
return arr.map(v => {
|
|
185
|
+
const tableName = v.tablename;
|
|
186
|
+
return {
|
|
187
|
+
value: tableName,
|
|
188
|
+
label: tableName,
|
|
189
|
+
dbName,
|
|
190
|
+
dbType,
|
|
191
|
+
tableName,
|
|
192
|
+
tableType,
|
|
193
|
+
};
|
|
194
|
+
});
|
|
195
|
+
};
|
|
196
|
+
const tableNames = await toSelectOptions(tableListSql, 'table');
|
|
197
|
+
const viewNames = await toSelectOptions(viewListSql, 'view');
|
|
198
|
+
const tableNameMerge = [...tableNames, ...viewNames];
|
|
199
|
+
return common_dto_1.CommonResult.successRes(tableNameMerge);
|
|
200
|
+
}
|
|
201
|
+
async getTableFieldsOfSqlServer(dbName, tableName) {
|
|
202
|
+
const dbConfig = this.sqlserver2Config[dbName];
|
|
203
|
+
if (!dbConfig) {
|
|
204
|
+
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
205
|
+
}
|
|
206
|
+
const columnArraySql = '' +
|
|
207
|
+
'SELECT\n' +
|
|
208
|
+
' c.name AS column_name,\n' +
|
|
209
|
+
' t.name AS data_type,\n' +
|
|
210
|
+
' c.max_length AS max_length,\n' +
|
|
211
|
+
' c.precision,\n' +
|
|
212
|
+
' c.scale,\n' +
|
|
213
|
+
' c.is_nullable,\n' +
|
|
214
|
+
' c.is_identity,\n' +
|
|
215
|
+
' dc.definition AS column_default, \n' +
|
|
216
|
+
' ep.value AS column_description \n' +
|
|
217
|
+
'FROM\n' +
|
|
218
|
+
' sys.columns c\n' +
|
|
219
|
+
' JOIN\n' +
|
|
220
|
+
' sys.types t ON c.user_type_id = t.user_type_id\n' +
|
|
221
|
+
' LEFT JOIN\n' +
|
|
222
|
+
' sys.default_constraints dc\n' +
|
|
223
|
+
' ON c.default_object_id = dc.object_id \n' +
|
|
224
|
+
' LEFT JOIN\n' +
|
|
225
|
+
' sys.extended_properties ep\n' +
|
|
226
|
+
' ON c.object_id = ep.major_id\n' +
|
|
227
|
+
' AND c.column_id = ep.minor_id\n' +
|
|
228
|
+
'WHERE\n' +
|
|
229
|
+
` c.object_id = OBJECT_ID('${tableName}') \n` +
|
|
230
|
+
' ORDER BY\n' +
|
|
231
|
+
' c.column_id;';
|
|
232
|
+
const dbType = keys_1.SqlDbType.sqlserver;
|
|
233
|
+
const columnArray = await this.curdMixService.executeSQL({
|
|
234
|
+
executeSql: columnArraySql,
|
|
235
|
+
sqlDatabase: dbName,
|
|
236
|
+
sqlDbType: dbType,
|
|
237
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
238
|
+
executeSqlArgs: [],
|
|
239
|
+
});
|
|
240
|
+
const fields = columnArray.map(columnObj => {
|
|
241
|
+
const { column_name, is_nullable, column_default, data_type, is_identity, column_description, ...others } = columnObj;
|
|
242
|
+
return {
|
|
243
|
+
fieldIndex: column_name || '',
|
|
244
|
+
fieldTitle: column_description || column_name || '',
|
|
245
|
+
isNullable: is_nullable,
|
|
246
|
+
defaultValue: column_default || '',
|
|
247
|
+
extra: others,
|
|
248
|
+
// key: column_name, // 索引
|
|
249
|
+
type: data_type,
|
|
250
|
+
is_identity: is_identity,
|
|
251
|
+
};
|
|
252
|
+
});
|
|
253
|
+
return common_dto_1.CommonResult.successRes({
|
|
254
|
+
fields,
|
|
255
|
+
tableName,
|
|
256
|
+
tableTitle: tableName,
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
async getTableFieldsOfPostgreSQL(dbName, tableName) {
|
|
260
|
+
const dbConfig = this.postgres2Config[dbName];
|
|
261
|
+
if (!dbConfig) {
|
|
262
|
+
throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
|
|
263
|
+
}
|
|
264
|
+
const schemaname = 'public';
|
|
265
265
|
const columnArraySql = `
|
|
266
266
|
|
|
267
267
|
SELECT
|
|
@@ -270,46 +270,46 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
|
|
|
270
270
|
WHERE table_schema = $1 and table_name = $2
|
|
271
271
|
ORDER BY ordinal_position;
|
|
272
272
|
|
|
273
|
-
`.trim();
|
|
274
|
-
const dbType = keys_1.SqlDbType.postgres;
|
|
275
|
-
const columnArray = await this.curdMixService.executeSQL({
|
|
276
|
-
executeSql: columnArraySql,
|
|
277
|
-
sqlDatabase: dbName,
|
|
278
|
-
sqlDbType: dbType,
|
|
279
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
280
|
-
executeSqlArgs: [schemaname, tableName],
|
|
281
|
-
});
|
|
282
|
-
const commentMap = await this.getTableFieldsCommentsMapOfPostgreSQL(dbName, schemaname, tableName);
|
|
283
|
-
const fields = columnArray.map(columnObj => {
|
|
284
|
-
const { column_name, is_nullable, column_default, data_type, is_identity, ...others } = columnObj;
|
|
285
|
-
return {
|
|
286
|
-
fieldIndex: column_name || '',
|
|
287
|
-
fieldTitle: commentMap[column_name] || column_name || '',
|
|
288
|
-
isNullable: is_nullable,
|
|
289
|
-
defaultValue: column_default || '',
|
|
290
|
-
extra: others,
|
|
291
|
-
// key: column_name, // 索引
|
|
292
|
-
type: data_type,
|
|
293
|
-
is_identity: is_identity,
|
|
294
|
-
};
|
|
295
|
-
});
|
|
296
|
-
return {
|
|
297
|
-
success: true,
|
|
298
|
-
data: {
|
|
299
|
-
fields,
|
|
300
|
-
tableName,
|
|
301
|
-
tableTitle: tableName,
|
|
302
|
-
},
|
|
303
|
-
};
|
|
304
|
-
}
|
|
305
|
-
/**
|
|
306
|
-
* 获取PostgreSQL建表语句的注释
|
|
307
|
-
* @param dbName
|
|
308
|
-
* @param schemaname
|
|
309
|
-
* @param tableName
|
|
310
|
-
* @returns
|
|
311
|
-
*/
|
|
312
|
-
async getTableFieldsCommentsMapOfPostgreSQL(dbName, schemaname, tableName) {
|
|
273
|
+
`.trim();
|
|
274
|
+
const dbType = keys_1.SqlDbType.postgres;
|
|
275
|
+
const columnArray = await this.curdMixService.executeSQL({
|
|
276
|
+
executeSql: columnArraySql,
|
|
277
|
+
sqlDatabase: dbName,
|
|
278
|
+
sqlDbType: dbType,
|
|
279
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
280
|
+
executeSqlArgs: [schemaname, tableName],
|
|
281
|
+
});
|
|
282
|
+
const commentMap = await this.getTableFieldsCommentsMapOfPostgreSQL(dbName, schemaname, tableName);
|
|
283
|
+
const fields = columnArray.map(columnObj => {
|
|
284
|
+
const { column_name, is_nullable, column_default, data_type, is_identity, ...others } = columnObj;
|
|
285
|
+
return {
|
|
286
|
+
fieldIndex: column_name || '',
|
|
287
|
+
fieldTitle: commentMap[column_name] || column_name || '',
|
|
288
|
+
isNullable: is_nullable,
|
|
289
|
+
defaultValue: column_default || '',
|
|
290
|
+
extra: others,
|
|
291
|
+
// key: column_name, // 索引
|
|
292
|
+
type: data_type,
|
|
293
|
+
is_identity: is_identity,
|
|
294
|
+
};
|
|
295
|
+
});
|
|
296
|
+
return {
|
|
297
|
+
success: true,
|
|
298
|
+
data: {
|
|
299
|
+
fields,
|
|
300
|
+
tableName,
|
|
301
|
+
tableTitle: tableName,
|
|
302
|
+
},
|
|
303
|
+
};
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* 获取PostgreSQL建表语句的注释
|
|
307
|
+
* @param dbName
|
|
308
|
+
* @param schemaname
|
|
309
|
+
* @param tableName
|
|
310
|
+
* @returns
|
|
311
|
+
*/
|
|
312
|
+
async getTableFieldsCommentsMapOfPostgreSQL(dbName, schemaname, tableName) {
|
|
313
313
|
const commentArraySql = `
|
|
314
314
|
SELECT
|
|
315
315
|
n.nspname AS schema_name,
|
|
@@ -330,66 +330,66 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
|
|
|
330
330
|
AND a.attnum > 0
|
|
331
331
|
ORDER BY
|
|
332
332
|
a.attnum
|
|
333
|
-
`;
|
|
334
|
-
const dbType = keys_1.SqlDbType.postgres;
|
|
335
|
-
const commentArray = await this.curdMixService.executeSQL({
|
|
336
|
-
executeSql: commentArraySql,
|
|
337
|
-
sqlDatabase: dbName,
|
|
338
|
-
sqlDbType: dbType,
|
|
339
|
-
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
340
|
-
executeSqlArgs: [schemaname, tableName],
|
|
341
|
-
});
|
|
342
|
-
const map = {};
|
|
343
|
-
commentArray.forEach(commentObj => {
|
|
344
|
-
const { column_name, column_comment } = commentObj;
|
|
345
|
-
map[column_name] = (0, parseCreateSql_1.parseTableFieldTitleFromComment)(column_comment);
|
|
346
|
-
});
|
|
347
|
-
return map;
|
|
348
|
-
}
|
|
349
|
-
};
|
|
350
|
-
__decorate([
|
|
351
|
-
(0, core_1.Config)('mysql2'),
|
|
352
|
-
__metadata("design:type", Object)
|
|
353
|
-
], CrudStandardDesignApi.prototype, "mysql2Config", void 0);
|
|
354
|
-
__decorate([
|
|
355
|
-
(0, core_1.Config)('postgres2'),
|
|
356
|
-
__metadata("design:type", Object)
|
|
357
|
-
], CrudStandardDesignApi.prototype, "postgres2Config", void 0);
|
|
358
|
-
__decorate([
|
|
359
|
-
(0, core_1.Config)('sqlserver2'),
|
|
360
|
-
__metadata("design:type", Object)
|
|
361
|
-
], CrudStandardDesignApi.prototype, "sqlserver2Config", void 0);
|
|
362
|
-
__decorate([
|
|
363
|
-
(0, core_1.Post)('/getDataBaseList'),
|
|
364
|
-
__metadata("design:type", Function),
|
|
365
|
-
__metadata("design:paramtypes", []),
|
|
366
|
-
__metadata("design:returntype", Promise)
|
|
367
|
-
], CrudStandardDesignApi.prototype, "getDataBaseList", null);
|
|
368
|
-
__decorate([
|
|
369
|
-
(0, core_1.Post)('/getTableList'),
|
|
370
|
-
__metadata("design:type", Function),
|
|
371
|
-
__metadata("design:paramtypes", []),
|
|
372
|
-
__metadata("design:returntype", Promise)
|
|
373
|
-
], CrudStandardDesignApi.prototype, "getTableList", null);
|
|
374
|
-
__decorate([
|
|
375
|
-
(0, core_1.Post)('/getTableFields'),
|
|
376
|
-
__metadata("design:type", Function),
|
|
377
|
-
__metadata("design:paramtypes", []),
|
|
378
|
-
__metadata("design:returntype", Promise)
|
|
379
|
-
], CrudStandardDesignApi.prototype, "getTableFields", null);
|
|
380
|
-
__decorate([
|
|
381
|
-
(0, core_1.Post)('/getRoleOptionsList'),
|
|
382
|
-
__metadata("design:type", Function),
|
|
383
|
-
__metadata("design:paramtypes", []),
|
|
384
|
-
__metadata("design:returntype", Promise)
|
|
385
|
-
], CrudStandardDesignApi.prototype, "getRoleOptionsList", null);
|
|
386
|
-
__decorate([
|
|
387
|
-
(0, core_1.Post)('/getFuncOptionsList'),
|
|
388
|
-
__metadata("design:type", Function),
|
|
389
|
-
__metadata("design:paramtypes", []),
|
|
390
|
-
__metadata("design:returntype", Promise)
|
|
391
|
-
], CrudStandardDesignApi.prototype, "getFuncOptionsList", null);
|
|
392
|
-
CrudStandardDesignApi = __decorate([
|
|
393
|
-
(0, core_1.Controller)('/ns/api/manage/CrudStandardDesignApi', { middleware: [(0, permission_middleware_1.checkPermission)(SystemPerm_1.SystemFuncCode.CrudStandardDesignRead)] })
|
|
394
|
-
], CrudStandardDesignApi);
|
|
395
|
-
exports.CrudStandardDesignApi = CrudStandardDesignApi;
|
|
333
|
+
`;
|
|
334
|
+
const dbType = keys_1.SqlDbType.postgres;
|
|
335
|
+
const commentArray = await this.curdMixService.executeSQL({
|
|
336
|
+
executeSql: commentArraySql,
|
|
337
|
+
sqlDatabase: dbName,
|
|
338
|
+
sqlDbType: dbType,
|
|
339
|
+
crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
|
|
340
|
+
executeSqlArgs: [schemaname, tableName],
|
|
341
|
+
});
|
|
342
|
+
const map = {};
|
|
343
|
+
commentArray.forEach(commentObj => {
|
|
344
|
+
const { column_name, column_comment } = commentObj;
|
|
345
|
+
map[column_name] = (0, parseCreateSql_1.parseTableFieldTitleFromComment)(column_comment);
|
|
346
|
+
});
|
|
347
|
+
return map;
|
|
348
|
+
}
|
|
349
|
+
};
|
|
350
|
+
__decorate([
|
|
351
|
+
(0, core_1.Config)('mysql2'),
|
|
352
|
+
__metadata("design:type", Object)
|
|
353
|
+
], CrudStandardDesignApi.prototype, "mysql2Config", void 0);
|
|
354
|
+
__decorate([
|
|
355
|
+
(0, core_1.Config)('postgres2'),
|
|
356
|
+
__metadata("design:type", Object)
|
|
357
|
+
], CrudStandardDesignApi.prototype, "postgres2Config", void 0);
|
|
358
|
+
__decorate([
|
|
359
|
+
(0, core_1.Config)('sqlserver2'),
|
|
360
|
+
__metadata("design:type", Object)
|
|
361
|
+
], CrudStandardDesignApi.prototype, "sqlserver2Config", void 0);
|
|
362
|
+
__decorate([
|
|
363
|
+
(0, core_1.Post)('/getDataBaseList'),
|
|
364
|
+
__metadata("design:type", Function),
|
|
365
|
+
__metadata("design:paramtypes", []),
|
|
366
|
+
__metadata("design:returntype", Promise)
|
|
367
|
+
], CrudStandardDesignApi.prototype, "getDataBaseList", null);
|
|
368
|
+
__decorate([
|
|
369
|
+
(0, core_1.Post)('/getTableList'),
|
|
370
|
+
__metadata("design:type", Function),
|
|
371
|
+
__metadata("design:paramtypes", []),
|
|
372
|
+
__metadata("design:returntype", Promise)
|
|
373
|
+
], CrudStandardDesignApi.prototype, "getTableList", null);
|
|
374
|
+
__decorate([
|
|
375
|
+
(0, core_1.Post)('/getTableFields'),
|
|
376
|
+
__metadata("design:type", Function),
|
|
377
|
+
__metadata("design:paramtypes", []),
|
|
378
|
+
__metadata("design:returntype", Promise)
|
|
379
|
+
], CrudStandardDesignApi.prototype, "getTableFields", null);
|
|
380
|
+
__decorate([
|
|
381
|
+
(0, core_1.Post)('/getRoleOptionsList'),
|
|
382
|
+
__metadata("design:type", Function),
|
|
383
|
+
__metadata("design:paramtypes", []),
|
|
384
|
+
__metadata("design:returntype", Promise)
|
|
385
|
+
], CrudStandardDesignApi.prototype, "getRoleOptionsList", null);
|
|
386
|
+
__decorate([
|
|
387
|
+
(0, core_1.Post)('/getFuncOptionsList'),
|
|
388
|
+
__metadata("design:type", Function),
|
|
389
|
+
__metadata("design:paramtypes", []),
|
|
390
|
+
__metadata("design:returntype", Promise)
|
|
391
|
+
], CrudStandardDesignApi.prototype, "getFuncOptionsList", null);
|
|
392
|
+
CrudStandardDesignApi = __decorate([
|
|
393
|
+
(0, core_1.Controller)('/ns/api/manage/CrudStandardDesignApi', { middleware: [(0, permission_middleware_1.checkPermission)(SystemPerm_1.SystemFuncCode.CrudStandardDesignRead)] })
|
|
394
|
+
], CrudStandardDesignApi);
|
|
395
|
+
exports.CrudStandardDesignApi = CrudStandardDesignApi;
|