midway-fatcms 0.0.1-beta.22 → 0.0.1-beta.25
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 -12
- 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 +187 -185
- package/dist/config/seed/aeskey.txt +1 -1
- 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 -114
- package/dist/controller/base/BaseApiController.d.ts +37 -31
- package/dist/controller/base/BaseApiController.js +164 -146
- 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 -14
- package/dist/controller/gateway/AsyncTaskController.js +181 -108
- package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
- package/dist/controller/gateway/CrudMtdGatewayController.js +119 -119
- package/dist/controller/gateway/CrudStdGatewayController.d.ts +38 -38
- package/dist/controller/gateway/CrudStdGatewayController.js +137 -137
- package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
- package/dist/controller/gateway/DocGatewayController.js +179 -179
- package/dist/controller/gateway/FileController.d.ts +25 -25
- package/dist/controller/gateway/FileController.js +129 -129
- package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
- package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
- package/dist/controller/gateway/PublicApiController.d.ts +27 -27
- package/dist/controller/gateway/PublicApiController.js +165 -165
- package/dist/controller/gateway/StaticController.d.ts +24 -23
- package/dist/controller/gateway/StaticController.js +288 -284
- 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 +71 -71
- 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 +38 -38
- package/dist/controller/manage/CrudStandardDesignApi.js +334 -334
- 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 +91 -91
- 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 +102 -101
- package/dist/index.js +120 -119
- 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 +163 -163
- package/dist/libs/crud-pro/interfaces.js +12 -12
- package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -43
- 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 +29 -29
- package/dist/libs/crud-pro/models/Transaction.js +67 -67
- 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 +106 -106
- package/dist/libs/crud-pro/models/keys.js +149 -149
- 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 +112 -112
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -223
- 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 +340 -340
- 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 +79 -79
- package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -9
- package/dist/libs/crud-pro/services/CrudProTableMetaService.js +78 -78
- 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/sql.txt +120 -120
- 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 +49 -49
- 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 +45 -45
- package/dist/libs/global-config/global-config.js +33 -33
- 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 -4
- package/dist/libs/utils/functions.js +68 -63
- 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 +7 -7
- package/dist/libs/utils/parseConfig.js +44 -44
- package/dist/libs/utils/parseCreateSql.d.ts +5 -5
- package/dist/libs/utils/parseCreateSql.js +86 -86
- package/dist/libs/utils/render-utils.d.ts +28 -28
- package/dist/libs/utils/render-utils.js +135 -135
- 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 +253 -253
- package/dist/middleware/permission.middleware.d.ts +18 -18
- package/dist/middleware/permission.middleware.js +74 -74
- package/dist/middleware/tx.middleware.d.ts +9 -9
- package/dist/middleware/tx.middleware.js +40 -40
- package/dist/models/AsyncTaskModel.d.ts +72 -69
- package/dist/models/AsyncTaskModel.js +29 -26
- package/dist/models/RedisKeys.d.ts +12 -8
- package/dist/models/RedisKeys.js +15 -11
- package/dist/models/SystemEntities.d.ts +98 -98
- package/dist/models/SystemEntities.js +2 -2
- 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 +96 -69
- package/dist/models/bizmodels.js +39 -34
- 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 +61 -61
- package/dist/models/userSession.js +165 -165
- package/dist/schedule/anonymousContext.d.ts +14 -13
- 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 -15
- 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 +70 -70
- package/dist/service/AuthService.js +251 -251
- package/dist/service/EnumInfoService.d.ts +30 -30
- package/dist/service/EnumInfoService.js +127 -126
- 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 +16 -16
- package/dist/service/UserSessionService.js +86 -86
- package/dist/service/VisitStatService.d.ts +14 -14
- package/dist/service/VisitStatService.js +158 -158
- package/dist/service/WorkbenchService.d.ts +20 -20
- package/dist/service/WorkbenchService.js +159 -155
- 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 +37 -37
- package/dist/service/asyncTask/AsyncTaskRunnerService.js +242 -232
- 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 -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 +130 -0
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +121 -0
- 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 -29
- package/dist/service/base/BaseService.js +101 -79
- package/dist/service/base/RedisCacheService.d.ts +13 -13
- package/dist/service/base/RedisCacheService.js +50 -50
- 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 +85 -85
- package/dist/service/crudstd/CrudStdService.d.ts +63 -51
- package/dist/service/crudstd/CrudStdService.js +259 -227
- package/dist/service/curd/CrudProQuick.d.ts +24 -24
- package/dist/service/curd/CrudProQuick.js +109 -105
- package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
- package/dist/service/curd/CurdMixByAccountService.js +93 -93
- package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
- package/dist/service/curd/CurdMixByDictService.js +114 -113
- package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -31
- package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -202
- 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 +27 -17
- package/dist/service/curd/CurdMixService.js +100 -76
- package/dist/service/curd/CurdMixUtils.d.ts +51 -35
- package/dist/service/curd/CurdMixUtils.js +275 -238
- package/dist/service/curd/CurdProService.d.ts +32 -31
- package/dist/service/curd/CurdProService.js +210 -207
- package/dist/service/curd/fixCfgModel.d.ts +3 -3
- package/dist/service/curd/fixCfgModel.js +107 -107
- package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
- package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
- package/dist/service/proxyapi/ProxyApiService.d.ts +60 -60
- package/dist/service/proxyapi/ProxyApiService.js +260 -260
- 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/dist/views/404_app.html +31 -31
- package/dist/views/404_workbench.html +34 -34
- package/index.d.ts +10 -10
- package/package.json +80 -78
- package/src/config/config.default.ts +207 -203
- package/src/config/seed/aeskey.txt +1 -1
- package/src/config/utils.ts +2 -3
- package/src/configuration.ts +5 -12
- package/src/controller/base/BaseApiController.ts +21 -3
- package/src/controller/gateway/AsyncTaskController.ts +76 -2
- package/src/controller/gateway/StaticController.ts +15 -12
- package/src/controller/manage/AnyApiMangeApi.ts +66 -66
- package/src/controller/manage/AppLogMangeApi.ts +53 -53
- package/src/controller/manage/AppMangeApi.ts +53 -53
- package/src/controller/manage/AppPageMangeApi.ts +52 -52
- package/src/controller/manage/AppSchemaHistoryApi.ts +49 -49
- package/src/controller/manage/CrudMethodsMangeApi.ts +49 -49
- package/src/controller/manage/DataDictManageApi.ts +78 -78
- package/src/controller/manage/DocLibManageApi.ts +69 -69
- package/src/controller/manage/DocManageApi.ts +99 -99
- package/src/controller/manage/FileManageApi.ts +45 -45
- package/src/controller/manage/LowCodeTplManageApi.ts +52 -52
- package/src/controller/manage/MenuManageApi.ts +58 -58
- package/src/controller/manage/ProxyApiMangeApi.ts +52 -52
- package/src/controller/manage/SysConfigMangeApi.ts +95 -95
- package/src/controller/manage/UserAccountManageApi.ts +94 -94
- package/src/controller/manage/WorkbenchMangeApi.ts +72 -72
- package/src/index.ts +106 -105
- package/src/interface.ts +31 -31
- package/src/libs/crud-pro/models/ExecuteContext.ts +13 -4
- package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +2 -3
- package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +8 -9
- package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -86
- package/src/libs/crud-pro/sql.txt +120 -120
- package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +26 -26
- package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +25 -25
- package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +11 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +11 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +129 -129
- package/src/libs/utils/functions.ts +73 -67
- package/src/libs/utils/render-utils.ts +184 -184
- package/src/middleware/permission.middleware.ts +1 -2
- package/src/models/AsyncTaskModel.ts +9 -6
- package/src/models/RedisKeys.ts +11 -11
- package/src/models/SystemEntities.ts +115 -115
- package/src/models/SystemPerm.ts +105 -105
- package/src/models/SystemTables.ts +27 -27
- package/src/models/bizmodels.ts +120 -88
- package/src/models/contextLogger.ts +132 -132
- package/src/models/devops.ts +17 -17
- package/src/models/userSession.ts +216 -216
- package/src/schedule/anonymousContext.ts +17 -23
- package/src/schedule/index.ts +12 -12
- package/src/schedule/runSchedule.ts +82 -83
- package/src/schedule/scheduleNames.ts +21 -21
- package/src/service/AuthService.ts +7 -10
- package/src/service/EnumInfoService.ts +24 -28
- package/src/service/FileCenterService.ts +4 -9
- package/src/service/SysConfigService.ts +4 -5
- package/src/service/UserAccountService.ts +107 -110
- package/src/service/UserSessionService.ts +12 -16
- package/src/service/WorkbenchService.ts +15 -15
- package/src/service/anyapi/AnyApiService.ts +1 -2
- package/src/service/asyncTask/AsyncTaskRunnerService.ts +22 -11
- package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
- package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
- package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +147 -0
- package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +138 -0
- package/src/service/base/ApiBaseService.ts +3 -3
- package/src/service/base/ApiRateLimiter.ts +59 -59
- package/src/service/base/BaseService.ts +100 -74
- package/src/service/base/RedisCacheService.ts +38 -38
- package/src/service/crudstd/CrudStdActionService.ts +27 -27
- package/src/service/crudstd/CrudStdConstant.ts +62 -62
- package/src/service/crudstd/CrudStdRelationService.ts +78 -78
- package/src/service/crudstd/CrudStdService.ts +283 -243
- package/src/service/curd/CrudProQuick.ts +11 -17
- package/src/service/curd/CurdMixByAccountService.ts +8 -9
- package/src/service/curd/CurdMixByDictService.ts +19 -24
- package/src/service/curd/CurdMixByLinkToCustomService.ts +10 -9
- package/src/service/curd/CurdMixBySysConfigService.ts +8 -13
- package/src/service/curd/CurdMixByWorkbenchService.ts +7 -8
- package/src/service/curd/CurdMixService.ts +37 -5
- package/src/service/curd/CurdMixUtils.ts +65 -45
- package/src/service/curd/CurdProService.ts +42 -48
- package/src/service/curd/fixCfgModel.ts +139 -139
- package/src/service/proxyapi/ProxyApiLoadService.ts +174 -174
- package/src/service/proxyapi/ProxyApiService.ts +262 -262
- package/src/service/proxyapi/ProxyApiUtils.ts +32 -32
- package/src/service/proxyapi/RouteHandler.ts +8 -8
- package/src/service/proxyapi/RouteTrie.ts +74 -74
- package/src/service/proxyapi/WeightedRandom.ts +37 -37
- package/src/service/proxyapi/WeightedRoundRobin.ts +44 -44
- package/src/views/404_app.html +31 -31
- package/src/views/404_workbench.html +34 -34
- package/tsconfig.json +32 -32
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
import {Inject, Provide} from '@midwayjs/core';
|
|
2
|
-
import {Context} from '@midwayjs/koa';
|
|
3
|
-
import {parseJsonObject} from '@/libs/utils/functions';
|
|
4
|
-
import {ISessionInfo, SESSION_ID_KEY, sessionCookieCfg} from '@/models/userSession';
|
|
5
|
-
import {RedisCacheService} from
|
|
6
|
-
import {RedisKeys} from
|
|
7
|
-
|
|
1
|
+
import { Inject, Provide } from '@midwayjs/core';
|
|
2
|
+
import { Context } from '@midwayjs/koa';
|
|
3
|
+
import { parseJsonObject } from '@/libs/utils/functions';
|
|
4
|
+
import { ISessionInfo, SESSION_ID_KEY, sessionCookieCfg } from '@/models/userSession';
|
|
5
|
+
import { RedisCacheService } from './base/RedisCacheService';
|
|
6
|
+
import { RedisKeys } from '@/models/RedisKeys';
|
|
8
7
|
|
|
9
8
|
function pickUserAvatar(avatar: any): string {
|
|
10
9
|
if (!avatar) {
|
|
@@ -33,12 +32,11 @@ function pickUserAvatar(avatar: any): string {
|
|
|
33
32
|
return null;
|
|
34
33
|
}
|
|
35
34
|
|
|
36
|
-
|
|
37
35
|
const SESSION_KEEP_TIME_SECOND: number = 3600 * 24 * 30;
|
|
38
36
|
|
|
39
|
-
const toCacheKey = (sessionId: string): string =>{
|
|
37
|
+
const toCacheKey = (sessionId: string): string => {
|
|
40
38
|
return `${RedisKeys.USER_SESSION_PREFIX}${sessionId}`;
|
|
41
|
-
}
|
|
39
|
+
};
|
|
42
40
|
|
|
43
41
|
@Provide()
|
|
44
42
|
export class UserSessionService {
|
|
@@ -46,13 +44,12 @@ export class UserSessionService {
|
|
|
46
44
|
private ctx: Context;
|
|
47
45
|
|
|
48
46
|
@Inject()
|
|
49
|
-
private redisCacheService: RedisCacheService
|
|
50
|
-
|
|
47
|
+
private redisCacheService: RedisCacheService;
|
|
51
48
|
|
|
52
49
|
public async saveUserSession(sessionInfo: ISessionInfo) {
|
|
53
50
|
sessionInfo.avatar = pickUserAvatar(sessionInfo.avatar);
|
|
54
51
|
const sessionId = sessionInfo.sessionId;
|
|
55
|
-
await this.redisCacheService.setJsonObject(toCacheKey(sessionId), sessionInfo, SESSION_KEEP_TIME_SECOND)
|
|
52
|
+
await this.redisCacheService.setJsonObject(toCacheKey(sessionId), sessionInfo, SESSION_KEEP_TIME_SECOND);
|
|
56
53
|
}
|
|
57
54
|
|
|
58
55
|
/**
|
|
@@ -60,14 +57,14 @@ export class UserSessionService {
|
|
|
60
57
|
* @param sessionId
|
|
61
58
|
*/
|
|
62
59
|
public async removeUserSession(sessionId: string) {
|
|
63
|
-
return await this.redisCacheService.removeItem(toCacheKey(sessionId))
|
|
60
|
+
return await this.redisCacheService.removeItem(toCacheKey(sessionId));
|
|
64
61
|
}
|
|
65
62
|
|
|
66
63
|
private async getCurrentUserSessionForMiddleware1(sessionId: string): Promise<ISessionInfo> {
|
|
67
64
|
if (!sessionId) {
|
|
68
65
|
return null;
|
|
69
66
|
}
|
|
70
|
-
return await this.redisCacheService.getJsonObject(toCacheKey(sessionId))
|
|
67
|
+
return await this.redisCacheService.getJsonObject(toCacheKey(sessionId));
|
|
71
68
|
}
|
|
72
69
|
|
|
73
70
|
/**
|
|
@@ -78,5 +75,4 @@ export class UserSessionService {
|
|
|
78
75
|
const sessionId = cookies.get(SESSION_ID_KEY, sessionCookieCfg);
|
|
79
76
|
return this.getCurrentUserSessionForMiddleware1(sessionId);
|
|
80
77
|
}
|
|
81
|
-
|
|
82
78
|
}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { Inject, Provide } from '@midwayjs/core';
|
|
2
2
|
import { Context } from '@midwayjs/koa';
|
|
3
|
-
import { KeysOfSimpleSQL } from '
|
|
4
|
-
import { SystemTables} from '
|
|
3
|
+
import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
|
|
4
|
+
import { SystemTables } from '@/models/SystemTables';
|
|
5
5
|
import { BaseService } from './base/BaseService';
|
|
6
6
|
// import { LRUCache } from 'lru-cache';
|
|
7
7
|
import { CurdProService } from './curd/CurdProService';
|
|
8
|
-
import { CommonException } from '
|
|
9
|
-
import { parseJsonObject } from '
|
|
10
|
-
import { IWorkbenchEntity } from '
|
|
11
|
-
import { IScheduleService } from '
|
|
12
|
-
import { getDebugWorkbenchCode } from '
|
|
13
|
-
import { MixinUtils } from '
|
|
8
|
+
import { CommonException } from '@/libs/crud-pro/exceptions';
|
|
9
|
+
import { parseJsonObject } from '@/libs/utils/functions';
|
|
10
|
+
import { IWorkbenchEntity } from '@/models/SystemEntities';
|
|
11
|
+
import { IScheduleService } from '@/interface';
|
|
12
|
+
import { getDebugWorkbenchCode } from '@/libs/utils/fatcms-request';
|
|
13
|
+
import { MixinUtils } from '@/libs/crud-pro/utils/MixinUtils';
|
|
14
14
|
import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
|
|
15
15
|
//
|
|
16
16
|
// const lruCache = new LRUCache<string, any>({
|
|
@@ -24,7 +24,6 @@ const lruCache = new Map<string, any>();
|
|
|
24
24
|
const CACHE_KEY_WORKBENCH_LIST = 'CACHE_KEY_WORKBENCH_LIST';
|
|
25
25
|
const CACHE_KEY_DOMAIN_MAP = 'CACHE_KEY_DOMAIN_MAP';
|
|
26
26
|
|
|
27
|
-
|
|
28
27
|
@Provide()
|
|
29
28
|
export class WorkbenchService extends BaseService implements IScheduleService {
|
|
30
29
|
@Inject()
|
|
@@ -43,10 +42,8 @@ export class WorkbenchService extends BaseService implements IScheduleService {
|
|
|
43
42
|
}
|
|
44
43
|
|
|
45
44
|
public async getAllWorkbenchInfoList(isForceRefresh?: boolean): Promise<IWorkbenchEntity[]> {
|
|
46
|
-
|
|
47
45
|
const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
|
|
48
46
|
|
|
49
|
-
|
|
50
47
|
let listData = lruCache.get(CACHE_KEY_WORKBENCH_LIST);
|
|
51
48
|
if (!listData || isForceRefresh === true) {
|
|
52
49
|
const reqJson = { condition: {}, pageSize: 1000, limit: 1000 };
|
|
@@ -70,7 +67,7 @@ export class WorkbenchService extends BaseService implements IScheduleService {
|
|
|
70
67
|
const domainMap1 = MixinUtils.toMap(listData, (e: any) => e.workbench_domain); // 主域名。其他两个域名。
|
|
71
68
|
const domainMap2 = MixinUtils.toMap(listData, (e: any) => e.workbench_domain2);
|
|
72
69
|
const domainMap3 = MixinUtils.toMap(listData, (e: any) => e.workbench_domain3);
|
|
73
|
-
domainMap = {...domainMap1, ...domainMap2, ...domainMap3};
|
|
70
|
+
domainMap = { ...domainMap1, ...domainMap2, ...domainMap3 };
|
|
74
71
|
lruCache.set(CACHE_KEY_DOMAIN_MAP, domainMap);
|
|
75
72
|
}
|
|
76
73
|
return domainMap;
|
|
@@ -110,18 +107,21 @@ export class WorkbenchService extends BaseService implements IScheduleService {
|
|
|
110
107
|
//正式环境: 根据域名获取站点配置
|
|
111
108
|
const host = this.getCurrentHost();
|
|
112
109
|
const domainMap = await this.getAllWorkbenchInfoMap();
|
|
113
|
-
|
|
110
|
+
const workbenchInfo = domainMap[host];
|
|
111
|
+
if (workbenchInfo) {
|
|
112
|
+
return workbenchInfo;
|
|
113
|
+
}
|
|
114
|
+
return domainMap['*']; // 最后兜底
|
|
114
115
|
}
|
|
115
116
|
|
|
116
117
|
private getCurrentHost(): string {
|
|
117
118
|
const host = this.ctx.request.host;
|
|
118
119
|
if (!host) {
|
|
119
|
-
throw new CommonException('GET_CURRENT_HOST_ERROR','获取当前域名失败');
|
|
120
|
+
throw new CommonException('GET_CURRENT_HOST_ERROR', '获取当前域名失败');
|
|
120
121
|
}
|
|
121
122
|
return host;
|
|
122
123
|
}
|
|
123
124
|
|
|
124
|
-
|
|
125
125
|
public async isSupportCurrentWorkbench(workbench_code_array: string | string[]): Promise<boolean> {
|
|
126
126
|
// 本地调试模式
|
|
127
127
|
if (this.isEnableDebug() && this.isLocalEnv()) {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Inject, Provide } from '@midwayjs/core';
|
|
2
2
|
import { Context } from '@midwayjs/koa';
|
|
3
3
|
import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
|
|
4
|
-
import { SystemTables} from '@/models/SystemTables';
|
|
4
|
+
import { SystemTables } from '@/models/SystemTables';
|
|
5
5
|
import { LRUCache } from 'lru-cache';
|
|
6
6
|
import { BizException } from '@/models/devops';
|
|
7
7
|
import { CurdMixService } from '../curd/CurdMixService';
|
|
@@ -65,7 +65,6 @@ export class AnyApiService extends ApiBaseService {
|
|
|
65
65
|
}
|
|
66
66
|
|
|
67
67
|
private async getAnyApiMethod(methodCode: string): Promise<ISysAnyApiEntity> {
|
|
68
|
-
|
|
69
68
|
// 开发环境,不使用缓存
|
|
70
69
|
if (this.isEnableDebug()) {
|
|
71
70
|
return this._getAnyApiMethod(methodCode);
|
|
@@ -10,14 +10,10 @@ import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
|
|
|
10
10
|
import { errorToString } from '@/libs/utils/errorToString';
|
|
11
11
|
import { ANONYMOUS_CONTEXT } from '@/schedule';
|
|
12
12
|
import { RedisKeys } from '@/models/RedisKeys';
|
|
13
|
+
import { getCurrentFullMoment } from '@/libs/utils/functions';
|
|
14
|
+
import { ExportExcelAsyncTaskHandler } from './handler/ExportExcelAsyncTaskHandler';
|
|
13
15
|
|
|
14
|
-
const END_STATUS_LIST = [
|
|
15
|
-
SysAsyncTaskStatus.PART_SUCCEEDED,
|
|
16
|
-
SysAsyncTaskStatus.SUCCEEDED,
|
|
17
|
-
SysAsyncTaskStatus.FAILED,
|
|
18
|
-
SysAsyncTaskStatus.CANCELLED,
|
|
19
|
-
SysAsyncTaskStatus.PAUSED,
|
|
20
|
-
];
|
|
16
|
+
const END_STATUS_LIST = [SysAsyncTaskStatus.PART_SUCCEEDED, SysAsyncTaskStatus.SUCCEEDED, SysAsyncTaskStatus.FAILED, SysAsyncTaskStatus.CANCELLED, SysAsyncTaskStatus.PAUSED];
|
|
21
17
|
|
|
22
18
|
class AsyncTaskRunner {
|
|
23
19
|
isBusy = false;
|
|
@@ -35,6 +31,13 @@ class AsyncTaskRunner {
|
|
|
35
31
|
taskElement.task_status = SysAsyncTaskStatus.RUNNING;
|
|
36
32
|
|
|
37
33
|
try {
|
|
34
|
+
// 1. 更新当前这个任务的状态
|
|
35
|
+
await this.updateTaskStatus(taskElement, {
|
|
36
|
+
task_status: taskElement.task_status,
|
|
37
|
+
started_at: getCurrentFullMoment(),
|
|
38
|
+
updated_at: getCurrentFullMoment(),
|
|
39
|
+
});
|
|
40
|
+
|
|
38
41
|
// 任务状态的设置在自定义的执行器里面。
|
|
39
42
|
await this.executeTask(taskElement);
|
|
40
43
|
|
|
@@ -42,19 +45,21 @@ class AsyncTaskRunner {
|
|
|
42
45
|
if (!END_STATUS_LIST.includes(taskElement.task_status)) {
|
|
43
46
|
taskElement.task_status = SysAsyncTaskStatus.SUCCEEDED;
|
|
44
47
|
}
|
|
45
|
-
|
|
46
48
|
} catch (error) {
|
|
47
49
|
taskElement.task_status = SysAsyncTaskStatus.FAILED;
|
|
48
50
|
taskElement.error_message = errorToString(error);
|
|
49
51
|
}
|
|
50
52
|
|
|
51
53
|
try {
|
|
54
|
+
// 2. 更新当前这个任务的状态
|
|
52
55
|
await this.updateTaskStatus(taskElement, {
|
|
53
56
|
task_status: taskElement.task_status,
|
|
54
57
|
error_message: taskElement.error_message,
|
|
58
|
+
updated_at: getCurrentFullMoment(),
|
|
59
|
+
completed_at: getCurrentFullMoment(),
|
|
55
60
|
});
|
|
56
61
|
} catch (error) {
|
|
57
|
-
ANONYMOUS_CONTEXT.getApp().getCoreLogger().error('executeTaskList error', error);
|
|
62
|
+
ANONYMOUS_CONTEXT.getApp().getCoreLogger().error('[AsyncTaskRunner] executeTaskList error', error);
|
|
58
63
|
}
|
|
59
64
|
}
|
|
60
65
|
|
|
@@ -119,11 +124,17 @@ class AsyncTaskRunner {
|
|
|
119
124
|
*/
|
|
120
125
|
export const ASYNC_TASK_RUNNER = new AsyncTaskRunner();
|
|
121
126
|
|
|
127
|
+
//内置的异步任务处理器:EXCEL导出
|
|
128
|
+
ASYNC_TASK_RUNNER.taskHandlerMap.set('EXCEL_EXPORT', new ExportExcelAsyncTaskHandler());
|
|
129
|
+
|
|
122
130
|
/**
|
|
123
131
|
* Redis锁
|
|
124
132
|
*/
|
|
125
133
|
const ASYNC_TASK_LOCK = RedisKeys.ASYNC_TASK_LOCK;
|
|
126
134
|
|
|
135
|
+
/**
|
|
136
|
+
* 上次检查异步任务的时间点
|
|
137
|
+
*/
|
|
127
138
|
const ASYNC_TASK_RUNTIME_OBJ = {
|
|
128
139
|
LAST_CHECK_ASYNC_TASK_UPDATE_TIME: 0,
|
|
129
140
|
};
|
|
@@ -194,7 +205,7 @@ export class AsyncTaskRunnerService extends BaseService implements IScheduleServ
|
|
|
194
205
|
|
|
195
206
|
// 开始执行。
|
|
196
207
|
ASYNC_TASK_RUNNER.executeTaskList(taskList).then(() => {
|
|
197
|
-
console.log('ASYNC_TASK_RUNNER finished taskIds ==> ' + JSON.stringify(taskIds));
|
|
208
|
+
console.log('[AsyncTaskRunnerService] ASYNC_TASK_RUNNER finished taskIds ==> ' + JSON.stringify(taskIds));
|
|
198
209
|
});
|
|
199
210
|
}
|
|
200
211
|
|
|
@@ -220,7 +231,7 @@ export class AsyncTaskRunnerService extends BaseService implements IScheduleServ
|
|
|
220
231
|
try {
|
|
221
232
|
await this.fetchPendingTasks();
|
|
222
233
|
} catch (e) {
|
|
223
|
-
console.error('fetchPendingTasks error', errorToString(e));
|
|
234
|
+
console.error('[AsyncTaskRunnerService] fetchPendingTasks error', errorToString(e));
|
|
224
235
|
}
|
|
225
236
|
|
|
226
237
|
await this.redisService.del(ASYNC_TASK_LOCK);
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface IExcelHeaderInfo {
|
|
2
|
+
title: string;
|
|
3
|
+
dataIndex: string;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
export interface IExcelAsyncTaskHandler {
|
|
7
|
+
getExcelHeader(): Promise<IExcelHeaderInfo[]>;
|
|
8
|
+
getPageSize(): Promise<number>;
|
|
9
|
+
getTotalCount(): Promise<number>;
|
|
10
|
+
getExcelDataList(pageNo: number, pageSize: number): Promise<any[]>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
import { IMidwayKoaContext } from '@midwayjs/koa';
|
|
2
|
+
import { ISysAsyncTaskHandler, SysAsyncTaskContext, SysAsyncTaskStatus } from '@/models/AsyncTaskModel';
|
|
3
|
+
import { ANONYMOUS_CONTEXT } from '@/schedule';
|
|
4
|
+
import { IExcelHeaderInfo, IExcelAsyncTaskHandler } from './ExcelInfoModel';
|
|
5
|
+
import { SysAsyncFileFormat } from '@/models/AsyncTaskModel';
|
|
6
|
+
import { ExportExcelByStdCrudHandler } from './ExportExcelByStdCrudHandler';
|
|
7
|
+
import { ExportExcelByInnerHttpHandler } from './ExportExcelByInnerHttpHandler';
|
|
8
|
+
import { IStdCrudExportInputParams, StdCrudExportInputParamsAppType } from '@/models/bizmodels';
|
|
9
|
+
|
|
10
|
+
import * as _ from 'lodash';
|
|
11
|
+
import * as fastcsv from 'fast-csv';
|
|
12
|
+
import * as fs from 'node:fs';
|
|
13
|
+
import * as fs2 from 'node:fs/promises';
|
|
14
|
+
import * as path from 'node:path';
|
|
15
|
+
import { parseJsonObject } from '@/libs/utils/functions';
|
|
16
|
+
import { UserSessionInfo } from '@/models/userSession';
|
|
17
|
+
import { errorToString } from '@/libs/utils/errorToString';
|
|
18
|
+
|
|
19
|
+
const indexRef = { current: 0 };
|
|
20
|
+
|
|
21
|
+
async function createFileFolder(distFileFolder: string) {
|
|
22
|
+
try {
|
|
23
|
+
await fs2.access(distFileFolder);
|
|
24
|
+
} catch (e) {
|
|
25
|
+
await fs2.mkdir(distFileFolder, { recursive: true });
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
function getExcelAsyncTaskHandler(asyncTaskContext: SysAsyncTaskContext, ctx: IMidwayKoaContext): IExcelAsyncTaskHandler {
|
|
30
|
+
const inputParams: IStdCrudExportInputParams = parseJsonObject(asyncTaskContext?.task?.input_params);
|
|
31
|
+
if (inputParams && inputParams.appType === StdCrudExportInputParamsAppType.STD_CRUD) {
|
|
32
|
+
return new ExportExcelByStdCrudHandler(asyncTaskContext, inputParams, ctx);
|
|
33
|
+
}
|
|
34
|
+
if (inputParams && inputParams.appType === StdCrudExportInputParamsAppType.INNER_HTTP) {
|
|
35
|
+
return new ExportExcelByInnerHttpHandler(asyncTaskContext, inputParams, ctx);
|
|
36
|
+
}
|
|
37
|
+
throw new Error('[getExcelAsyncTaskHandler]appType不支持;appType = ' + inputParams.appType);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* 多实例,每个任务一个实例。
|
|
42
|
+
* 导出EXCEL异步任务:
|
|
43
|
+
*/
|
|
44
|
+
class ExportExcelAsyncTask {
|
|
45
|
+
protected asyncTaskContext: SysAsyncTaskContext;
|
|
46
|
+
protected ctx: IMidwayKoaContext;
|
|
47
|
+
protected headerColumns: IExcelHeaderInfo[];
|
|
48
|
+
protected excelAsyncTaskHandler: IExcelAsyncTaskHandler;
|
|
49
|
+
|
|
50
|
+
constructor(asyncTaskContext: SysAsyncTaskContext, ctx: IMidwayKoaContext) {
|
|
51
|
+
this.asyncTaskContext = asyncTaskContext;
|
|
52
|
+
this.ctx = ctx;
|
|
53
|
+
this.excelAsyncTaskHandler = getExcelAsyncTaskHandler(asyncTaskContext, ctx);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
private getDistFileFolder() {
|
|
57
|
+
const app = ANONYMOUS_CONTEXT.getApp();
|
|
58
|
+
const config = app.getConfig();
|
|
59
|
+
const fatcmsExportExcelTmpFilePath = config.fatcmsExportExcelTmpFilePath;
|
|
60
|
+
if (!fatcmsExportExcelTmpFilePath) {
|
|
61
|
+
return path.join(__dirname, '../../tmp');
|
|
62
|
+
}
|
|
63
|
+
return fatcmsExportExcelTmpFilePath;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
async executeWithContext() {
|
|
67
|
+
const taskElement = this.asyncTaskContext.task;
|
|
68
|
+
const taskId = _.get(this.asyncTaskContext, 'task.id');
|
|
69
|
+
|
|
70
|
+
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext start, taskId=' + taskId);
|
|
71
|
+
|
|
72
|
+
const pageSize = await this.excelAsyncTaskHandler.getPageSize();
|
|
73
|
+
|
|
74
|
+
const fileName = await this.getExcelFileName(); // 文件名
|
|
75
|
+
const distFileFolder = this.getDistFileFolder();
|
|
76
|
+
await createFileFolder(distFileFolder);
|
|
77
|
+
const diskFilePath = path.resolve(distFileFolder, fileName); // 磁盘文件路径
|
|
78
|
+
|
|
79
|
+
const totalCount = await this.getTotalCount();
|
|
80
|
+
|
|
81
|
+
await this.asyncTaskContext.updateTaskStatus({
|
|
82
|
+
output_total_records: totalCount,
|
|
83
|
+
output_file_format: SysAsyncFileFormat.CSV,
|
|
84
|
+
output_file_path: diskFilePath,
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
this.headerColumns = await this.getExcelHeader();
|
|
88
|
+
|
|
89
|
+
const ws = fs.createWriteStream(diskFilePath, {
|
|
90
|
+
encoding: 'utf-8',
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
const csvStream = fastcsv.format({ writeHeaders: false, headers: false, delimiter: ',' });
|
|
94
|
+
csvStream.pipe(ws);
|
|
95
|
+
csvStream.write('\ufeff'); // 写入BOM头,解决中文乱码问题
|
|
96
|
+
|
|
97
|
+
csvStream.write(this.formatToCsvHeader(this.headerColumns));
|
|
98
|
+
|
|
99
|
+
let processed_records = 0;
|
|
100
|
+
|
|
101
|
+
try {
|
|
102
|
+
if (typeof totalCount === 'number' && totalCount > 0) {
|
|
103
|
+
const batchCount = Math.ceil(totalCount / pageSize);
|
|
104
|
+
for (let i = 0; i < batchCount; i++) {
|
|
105
|
+
const num = await this.writeExcelBatchData(csvStream, i + 1, pageSize);
|
|
106
|
+
processed_records = processed_records + num;
|
|
107
|
+
const progress = Math.round((processed_records / totalCount) * 100);
|
|
108
|
+
await this.asyncTaskContext.updateTaskStatus({
|
|
109
|
+
processed_records,
|
|
110
|
+
progress,
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
taskElement.task_status = SysAsyncTaskStatus.SUCCEEDED;
|
|
116
|
+
} catch (error) {
|
|
117
|
+
taskElement.task_status = SysAsyncTaskStatus.FAILED;
|
|
118
|
+
taskElement.error_message = errorToString(error);
|
|
119
|
+
const progress = Math.round((processed_records / totalCount) * 100);
|
|
120
|
+
await this.asyncTaskContext.updateTaskStatus({
|
|
121
|
+
processed_records,
|
|
122
|
+
progress,
|
|
123
|
+
task_status: taskElement.task_status,
|
|
124
|
+
error_message: taskElement.error_message,
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
csvStream.end();
|
|
129
|
+
ws.on('finish', async () => {
|
|
130
|
+
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext finish, taskId=' + taskId);
|
|
131
|
+
const fsStat = await fs2.stat(diskFilePath);
|
|
132
|
+
const output_file_size = fsStat.size;
|
|
133
|
+
this.asyncTaskContext.updateTaskStatus({
|
|
134
|
+
output_file_size,
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext end, taskId=' + taskId);
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
private formatToCsvHeader(headerColumns: IExcelHeaderInfo[]): string[] {
|
|
141
|
+
return headerColumns.map(item => {
|
|
142
|
+
return item.title;
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
private async writeExcelBatchData(csvStream: fastcsv.CsvFormatterStream<any, any>, pageNo: number, pageSize: number): Promise<number> {
|
|
147
|
+
const dataList: any[] = await this.getExcelDataList(pageNo, pageSize);
|
|
148
|
+
for (let i = 0; i < dataList.length; i++) {
|
|
149
|
+
const csvRow = this.formatToCsvRow(dataList[i]);
|
|
150
|
+
csvStream.write(csvRow);
|
|
151
|
+
}
|
|
152
|
+
return dataList.length;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
private formatToCsvRow(rowObj: any): string[] {
|
|
156
|
+
return this.headerColumns.map(obj => {
|
|
157
|
+
const dataIndex = obj.dataIndex;
|
|
158
|
+
const value = _.get(rowObj, dataIndex);
|
|
159
|
+
if (typeof value === 'undefined' || value === null) {
|
|
160
|
+
return '';
|
|
161
|
+
}
|
|
162
|
+
if (typeof value !== 'string') {
|
|
163
|
+
// boolean , number
|
|
164
|
+
return '' + value;
|
|
165
|
+
}
|
|
166
|
+
return value;
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
/**
|
|
171
|
+
* 获取文件名
|
|
172
|
+
* @returns 文件名
|
|
173
|
+
*/
|
|
174
|
+
private async getExcelFileName() {
|
|
175
|
+
indexRef.current = indexRef.current + 1;
|
|
176
|
+
if (indexRef.current > 100000) {
|
|
177
|
+
indexRef.current = 1;
|
|
178
|
+
}
|
|
179
|
+
const num = `${indexRef.current}`.padStart(10);
|
|
180
|
+
return `export_${Date.now()}_${num}.csv`;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
/**
|
|
184
|
+
* 获取Excel的表头
|
|
185
|
+
* @returns
|
|
186
|
+
*/
|
|
187
|
+
private async getExcelHeader(): Promise<IExcelHeaderInfo[]> {
|
|
188
|
+
return this.excelAsyncTaskHandler.getExcelHeader();
|
|
189
|
+
// const inputParams = parseJsonObject(this.asyncTaskContext?.task?.input_params);
|
|
190
|
+
// if (inputParams && inputParams.appType === 'STD_CRUD') {
|
|
191
|
+
// // const appCode = inputParams.appCode;
|
|
192
|
+
// console.log(this)
|
|
193
|
+
// }
|
|
194
|
+
// return [
|
|
195
|
+
// { title: 'ID', dataIndex: 'id' },
|
|
196
|
+
// { title: '姓名', dataIndex: 'name' },
|
|
197
|
+
// { title: '邮箱', dataIndex: 'email' }
|
|
198
|
+
// ]
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
/**
|
|
202
|
+
* 获取文件总数
|
|
203
|
+
*/
|
|
204
|
+
private async getTotalCount(): Promise<number> {
|
|
205
|
+
const totalCount = await this.excelAsyncTaskHandler.getTotalCount();
|
|
206
|
+
// 最多导出10万条数据
|
|
207
|
+
return Math.min(totalCount, 10 * 10000);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* 获取数据内容数组
|
|
212
|
+
* @param pageNo 当前页号,从1开始
|
|
213
|
+
* @param pageSize 每页获取的数量。
|
|
214
|
+
*/
|
|
215
|
+
private async getExcelDataList(pageNo: number, pageSize: number): Promise<any[]> {
|
|
216
|
+
return this.excelAsyncTaskHandler.getExcelDataList(pageNo, pageSize);
|
|
217
|
+
// const dataList = [];
|
|
218
|
+
// for (var i = 0; i < pageSize; i++) {
|
|
219
|
+
// dataList.push({ id: i, name: 'nmae' + i, email: 'www.dss@dd.dom' })
|
|
220
|
+
// }
|
|
221
|
+
// return dataList;
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
/**
|
|
226
|
+
* 单例
|
|
227
|
+
*/
|
|
228
|
+
export class ExportExcelAsyncTaskHandler implements ISysAsyncTaskHandler {
|
|
229
|
+
public async execute(asyncTaskContext: SysAsyncTaskContext): Promise<any> {
|
|
230
|
+
const taskId = _.get(asyncTaskContext, 'task.id');
|
|
231
|
+
|
|
232
|
+
console.log('[ExportExcelAsyncTaskHandler] execute, taskId=>' + taskId);
|
|
233
|
+
|
|
234
|
+
const res = await ANONYMOUS_CONTEXT.runServiceAtAnonymousContext(async (ctx: IMidwayKoaContext) => {
|
|
235
|
+
const createdUserSession = parseJsonObject(asyncTaskContext?.task?.created_user_session);
|
|
236
|
+
ctx.userSession = new UserSessionInfo(createdUserSession, false);
|
|
237
|
+
const task = new ExportExcelAsyncTask(asyncTaskContext, ctx);
|
|
238
|
+
return task.executeWithContext();
|
|
239
|
+
});
|
|
240
|
+
if (res.error) {
|
|
241
|
+
throw res.error;
|
|
242
|
+
}
|
|
243
|
+
return res.result;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
import * as _ from 'lodash';
|
|
2
|
+
import axios from 'axios';
|
|
3
|
+
import { IMidwayKoaContext } from '@midwayjs/koa';
|
|
4
|
+
import { IExcelAsyncTaskHandler, IExcelHeaderInfo } from './ExcelInfoModel';
|
|
5
|
+
import { SysAsyncTaskContext } from '@/models/AsyncTaskModel';
|
|
6
|
+
import { IStdCrudExportInputParams, ITableProQueryParams } from '@/models/bizmodels';
|
|
7
|
+
import { IRequestModel } from '@/libs/crud-pro/interfaces';
|
|
8
|
+
import { ANONYMOUS_CONTEXT } from '@/schedule';
|
|
9
|
+
|
|
10
|
+
function pickData(a: any, key: string) {
|
|
11
|
+
if (a && typeof a.getResModel === 'function') {
|
|
12
|
+
const s = a.getResModel();
|
|
13
|
+
return s[key];
|
|
14
|
+
}
|
|
15
|
+
if (!a) {
|
|
16
|
+
throw 'ExportExcelByInnerHttpHandler返回数据不存在';
|
|
17
|
+
}
|
|
18
|
+
return _.get(a, `data.${key}`);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* 多实例,每个任务一个实例。
|
|
23
|
+
* 导出Excel。请求任务级别的。
|
|
24
|
+
* 使用内部HTTP接口导出
|
|
25
|
+
*/
|
|
26
|
+
class ExportExcelByInnerHttpHandler implements IExcelAsyncTaskHandler {
|
|
27
|
+
protected asyncTaskContext: SysAsyncTaskContext;
|
|
28
|
+
protected ctx: IMidwayKoaContext;
|
|
29
|
+
protected inputParams: IStdCrudExportInputParams;
|
|
30
|
+
protected appCode: string;
|
|
31
|
+
public constructor(asyncTaskContext: SysAsyncTaskContext, inputParams: IStdCrudExportInputParams, ctx: IMidwayKoaContext) {
|
|
32
|
+
this.ctx = ctx;
|
|
33
|
+
this.inputParams = inputParams;
|
|
34
|
+
this.asyncTaskContext = asyncTaskContext;
|
|
35
|
+
this.appCode = this.inputParams.appCode;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
async getPageSize(): Promise<number> {
|
|
39
|
+
if (typeof this.inputParams.pageSize === 'number') {
|
|
40
|
+
return Math.min(this.inputParams.pageSize, 1000);
|
|
41
|
+
}
|
|
42
|
+
return 1000;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* 获取Excel表的表头
|
|
47
|
+
* @returns 表头信息
|
|
48
|
+
*/
|
|
49
|
+
async getExcelHeader(): Promise<IExcelHeaderInfo[]> {
|
|
50
|
+
const columns = this.inputParams.columns;
|
|
51
|
+
if (!columns) {
|
|
52
|
+
throw new Error('导出Excel的表头信息不存在');
|
|
53
|
+
}
|
|
54
|
+
if (!Array.isArray(columns) || columns.length === 0) {
|
|
55
|
+
throw new Error('导出Excel的表头信息不是数组');
|
|
56
|
+
}
|
|
57
|
+
return columns
|
|
58
|
+
.map(cc => {
|
|
59
|
+
let { title, dataIndex } = cc;
|
|
60
|
+
if (!dataIndex) {
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
if (!title) {
|
|
64
|
+
title = '字段_' + dataIndex;
|
|
65
|
+
}
|
|
66
|
+
return { title, dataIndex };
|
|
67
|
+
})
|
|
68
|
+
.filter(Boolean);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
private async sendRequest(params: any): Promise<any> {
|
|
72
|
+
const port = ANONYMOUS_CONTEXT.getApp().getConfig().koa.port;
|
|
73
|
+
let queryApi = this.inputParams.innerHttpUrl; // 以斜杠开头
|
|
74
|
+
if (!queryApi.startsWith('/')) {
|
|
75
|
+
queryApi = '/' + queryApi;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
params.runByExportExcel = true;
|
|
79
|
+
|
|
80
|
+
const response = await axios({
|
|
81
|
+
method: 'POST',
|
|
82
|
+
url: `http://127.0.0.1:${port}${queryApi}`,
|
|
83
|
+
data: params,
|
|
84
|
+
headers: this.inputParams.headers || {},
|
|
85
|
+
responseType: 'json',
|
|
86
|
+
validateStatus: () => true,
|
|
87
|
+
});
|
|
88
|
+
if (response.status !== 200) {
|
|
89
|
+
throw new Error('导出Excel请求错误失败,状态码:' + response.status);
|
|
90
|
+
}
|
|
91
|
+
return response.data;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* 获取要导出的数量总数
|
|
96
|
+
* @returns 数据总量
|
|
97
|
+
*/
|
|
98
|
+
async getTotalCount(): Promise<number> {
|
|
99
|
+
const selectedRowKeys: string[] | number[] = this.inputParams?.selectedRowKeys || [];
|
|
100
|
+
if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
|
|
101
|
+
return selectedRowKeys.length;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const lastQueryParams: ITableProQueryParams = this.inputParams?.lastQueryParams;
|
|
105
|
+
const res = await this.sendRequest({
|
|
106
|
+
condition: lastQueryParams?.condition || {},
|
|
107
|
+
orderBy: lastQueryParams?.orderBy,
|
|
108
|
+
pageSize: 1,
|
|
109
|
+
pageNo: 1,
|
|
110
|
+
});
|
|
111
|
+
return pickData(res, 'total_count');
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* 获取要导出Excel的数据的内容
|
|
116
|
+
* @param pageNo 页号,从1开始
|
|
117
|
+
* @param pageSize 每页数量
|
|
118
|
+
* @returns
|
|
119
|
+
*/
|
|
120
|
+
async getExcelDataList(pageNo: number, pageSize: number): Promise<any[]> {
|
|
121
|
+
const selectedRowKeys: string[] | number[] = this.inputParams?.selectedRowKeys || [];
|
|
122
|
+
const lastQueryParams: ITableProQueryParams = this.inputParams?.lastQueryParams;
|
|
123
|
+
const primaryKey: string = this.inputParams.primaryKey || 'id';
|
|
124
|
+
|
|
125
|
+
const params: IRequestModel = {
|
|
126
|
+
condition: lastQueryParams?.condition || {},
|
|
127
|
+
pageSize: pageSize,
|
|
128
|
+
pageNo: pageNo,
|
|
129
|
+
orderBy: lastQueryParams?.orderBy,
|
|
130
|
+
};
|
|
131
|
+
|
|
132
|
+
if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
|
|
133
|
+
params.condition[primaryKey] = {
|
|
134
|
+
$in: selectedRowKeys,
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
const res = await this.sendRequest({
|
|
138
|
+
condition: lastQueryParams?.condition || {},
|
|
139
|
+
orderBy: lastQueryParams?.orderBy,
|
|
140
|
+
pageSize: pageSize,
|
|
141
|
+
pageNo: pageNo,
|
|
142
|
+
});
|
|
143
|
+
return pickData(res, 'rows');
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
export { ExportExcelByInnerHttpHandler };
|