midway-fatcms 0.0.1-beta.64 → 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 -8
- package/dist/libs/utils/parseConfig.js +47 -47
- 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 -104
- 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 -263
- 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 -70
- package/dist/service/crudstd/CrudStdService.js +403 -403
- 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/service/proxyapi/WeightedRandom.ts +1 -1
- package/src/service/proxyapi/WeightedRoundRobin.ts +1 -1
- package/tsconfig.json +32 -32
|
@@ -1,34 +1,34 @@
|
|
|
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.AsyncTaskService = void 0;
|
|
13
|
-
const core_1 = require("@midwayjs/core");
|
|
14
|
-
const BaseService_1 = require("../../service/base/BaseService");
|
|
15
|
-
const schedule_1 = require("../../schedule");
|
|
16
|
-
const scheduleNames_1 = require("../../schedule/scheduleNames");
|
|
17
|
-
const RedisKeys_1 = require("../../models/RedisKeys");
|
|
18
|
-
let AsyncTaskService = class AsyncTaskService extends BaseService_1.BaseService {
|
|
19
|
-
async startTask() {
|
|
20
|
-
await this.redisService.set(RedisKeys_1.RedisKeys.ASYNC_TASK_UPDATE_TIME, `${Date.now()}`);
|
|
21
|
-
(0, schedule_1.runScheduleTaskOnce)(scheduleNames_1.INNER_SCHEDULE_NAMES.asyncTaskRunnerService).then(schedule => {
|
|
22
|
-
console.log(schedule);
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
async cancelTask(id) { }
|
|
26
|
-
};
|
|
27
|
-
__decorate([
|
|
28
|
-
(0, core_1.Inject)(),
|
|
29
|
-
__metadata("design:type", Object)
|
|
30
|
-
], AsyncTaskService.prototype, "ctx", void 0);
|
|
31
|
-
AsyncTaskService = __decorate([
|
|
32
|
-
(0, core_1.Provide)()
|
|
33
|
-
], AsyncTaskService);
|
|
34
|
-
exports.AsyncTaskService = AsyncTaskService;
|
|
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.AsyncTaskService = void 0;
|
|
13
|
+
const core_1 = require("@midwayjs/core");
|
|
14
|
+
const BaseService_1 = require("../../service/base/BaseService");
|
|
15
|
+
const schedule_1 = require("../../schedule");
|
|
16
|
+
const scheduleNames_1 = require("../../schedule/scheduleNames");
|
|
17
|
+
const RedisKeys_1 = require("../../models/RedisKeys");
|
|
18
|
+
let AsyncTaskService = class AsyncTaskService extends BaseService_1.BaseService {
|
|
19
|
+
async startTask() {
|
|
20
|
+
await this.redisService.set(RedisKeys_1.RedisKeys.ASYNC_TASK_UPDATE_TIME, `${Date.now()}`);
|
|
21
|
+
(0, schedule_1.runScheduleTaskOnce)(scheduleNames_1.INNER_SCHEDULE_NAMES.asyncTaskRunnerService).then(schedule => {
|
|
22
|
+
console.log(schedule);
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
async cancelTask(id) { }
|
|
26
|
+
};
|
|
27
|
+
__decorate([
|
|
28
|
+
(0, core_1.Inject)(),
|
|
29
|
+
__metadata("design:type", Object)
|
|
30
|
+
], AsyncTaskService.prototype, "ctx", void 0);
|
|
31
|
+
AsyncTaskService = __decorate([
|
|
32
|
+
(0, core_1.Provide)()
|
|
33
|
+
], AsyncTaskService);
|
|
34
|
+
exports.AsyncTaskService = AsyncTaskService;
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
export interface IExcelHeaderInfo {
|
|
2
|
-
title: string;
|
|
3
|
-
dataIndex: string;
|
|
4
|
-
}
|
|
5
|
-
export interface IExcelAsyncTaskHandler {
|
|
6
|
-
getExcelHeader(): Promise<IExcelHeaderInfo[]>;
|
|
7
|
-
getPageSize(): Promise<number>;
|
|
8
|
-
getTotalCount(): Promise<number>;
|
|
9
|
-
getExcelDataList(pageNo: number, pageSize: number): Promise<any[]>;
|
|
10
|
-
}
|
|
1
|
+
export interface IExcelHeaderInfo {
|
|
2
|
+
title: string;
|
|
3
|
+
dataIndex: string;
|
|
4
|
+
}
|
|
5
|
+
export interface IExcelAsyncTaskHandler {
|
|
6
|
+
getExcelHeader(): Promise<IExcelHeaderInfo[]>;
|
|
7
|
+
getPageSize(): Promise<number>;
|
|
8
|
+
getTotalCount(): Promise<number>;
|
|
9
|
+
getExcelDataList(pageNo: number, pageSize: number): Promise<any[]>;
|
|
10
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { ISysAsyncTaskHandler, SysAsyncTaskContext } from '../../../models/AsyncTaskModel';
|
|
2
|
-
/**
|
|
3
|
-
* 单例
|
|
4
|
-
*/
|
|
5
|
-
export declare class ExportExcelAsyncTaskHandler implements ISysAsyncTaskHandler {
|
|
6
|
-
execute(asyncTaskContext: SysAsyncTaskContext): Promise<any>;
|
|
7
|
-
}
|
|
1
|
+
import { ISysAsyncTaskHandler, SysAsyncTaskContext } from '../../../models/AsyncTaskModel';
|
|
2
|
+
/**
|
|
3
|
+
* 单例
|
|
4
|
+
*/
|
|
5
|
+
export declare class ExportExcelAsyncTaskHandler implements ISysAsyncTaskHandler {
|
|
6
|
+
execute(asyncTaskContext: SysAsyncTaskContext): Promise<any>;
|
|
7
|
+
}
|
|
@@ -1,216 +1,216 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ExportExcelAsyncTaskHandler = void 0;
|
|
4
|
-
const AsyncTaskModel_1 = require("../../../models/AsyncTaskModel");
|
|
5
|
-
const schedule_1 = require("../../../schedule");
|
|
6
|
-
const AsyncTaskModel_2 = require("../../../models/AsyncTaskModel");
|
|
7
|
-
const ExportExcelByStdCrudHandler_1 = require("./ExportExcelByStdCrudHandler");
|
|
8
|
-
const ExportExcelByInnerHttpHandler_1 = require("./ExportExcelByInnerHttpHandler");
|
|
9
|
-
const bizmodels_1 = require("../../../models/bizmodels");
|
|
10
|
-
const _ = require("lodash");
|
|
11
|
-
const fastcsv = require("fast-csv");
|
|
12
|
-
const fs = require("node:fs");
|
|
13
|
-
const fs2 = require("node:fs/promises");
|
|
14
|
-
const path = require("node:path");
|
|
15
|
-
const functions_1 = require("../../../libs/utils/functions");
|
|
16
|
-
const userSession_1 = require("../../../models/userSession");
|
|
17
|
-
const errorToString_1 = require("../../../libs/utils/errorToString");
|
|
18
|
-
const indexRef = { current: 0 };
|
|
19
|
-
async function createFileFolder(distFileFolder) {
|
|
20
|
-
try {
|
|
21
|
-
await fs2.access(distFileFolder);
|
|
22
|
-
}
|
|
23
|
-
catch (e) {
|
|
24
|
-
await fs2.mkdir(distFileFolder, { recursive: true });
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
function getExcelAsyncTaskHandler(asyncTaskContext, ctx) {
|
|
28
|
-
var _a;
|
|
29
|
-
const inputParams = (0, functions_1.parseJsonObject)((_a = asyncTaskContext === null || asyncTaskContext === void 0 ? void 0 : asyncTaskContext.task) === null || _a === void 0 ? void 0 : _a.input_params);
|
|
30
|
-
if (inputParams && inputParams.appType === bizmodels_1.StdCrudExportInputParamsAppType.STD_CRUD) {
|
|
31
|
-
return new ExportExcelByStdCrudHandler_1.ExportExcelByStdCrudHandler(asyncTaskContext, inputParams, ctx);
|
|
32
|
-
}
|
|
33
|
-
if (inputParams && inputParams.appType === bizmodels_1.StdCrudExportInputParamsAppType.INNER_HTTP) {
|
|
34
|
-
return new ExportExcelByInnerHttpHandler_1.ExportExcelByInnerHttpHandler(asyncTaskContext, inputParams, ctx);
|
|
35
|
-
}
|
|
36
|
-
throw new Error('[getExcelAsyncTaskHandler]appType不支持;appType = ' + inputParams.appType);
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* 多实例,每个任务一个实例。
|
|
40
|
-
* 导出EXCEL异步任务:
|
|
41
|
-
*/
|
|
42
|
-
class ExportExcelAsyncTask {
|
|
43
|
-
constructor(asyncTaskContext, ctx) {
|
|
44
|
-
this.asyncTaskContext = asyncTaskContext;
|
|
45
|
-
this.ctx = ctx;
|
|
46
|
-
this.excelAsyncTaskHandler = getExcelAsyncTaskHandler(asyncTaskContext, ctx);
|
|
47
|
-
}
|
|
48
|
-
getDistFileFolder() {
|
|
49
|
-
const app = schedule_1.ANONYMOUS_CONTEXT.getApp();
|
|
50
|
-
const config = app.getConfig();
|
|
51
|
-
const fatcmsExportExcelTmpFilePath = config.fatcmsExportExcelTmpFilePath;
|
|
52
|
-
if (!fatcmsExportExcelTmpFilePath) {
|
|
53
|
-
return path.join(__dirname, '../../tmp');
|
|
54
|
-
}
|
|
55
|
-
return fatcmsExportExcelTmpFilePath;
|
|
56
|
-
}
|
|
57
|
-
async executeWithContext() {
|
|
58
|
-
const taskElement = this.asyncTaskContext.task;
|
|
59
|
-
const taskId = _.get(this.asyncTaskContext, 'task.id');
|
|
60
|
-
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext start, taskId=' + taskId);
|
|
61
|
-
const pageSize = await this.excelAsyncTaskHandler.getPageSize();
|
|
62
|
-
const fileName = await this.getExcelFileName(); // 文件名
|
|
63
|
-
const distFileFolder = this.getDistFileFolder();
|
|
64
|
-
await createFileFolder(distFileFolder);
|
|
65
|
-
const diskFilePath = path.resolve(distFileFolder, fileName); // 磁盘文件路径
|
|
66
|
-
const totalCount = await this.getTotalCount();
|
|
67
|
-
await this.asyncTaskContext.updateTaskStatus({
|
|
68
|
-
output_total_records: totalCount,
|
|
69
|
-
output_file_format: AsyncTaskModel_2.SysAsyncFileFormat.CSV,
|
|
70
|
-
output_file_path: diskFilePath,
|
|
71
|
-
});
|
|
72
|
-
this.headerColumns = await this.getExcelHeader();
|
|
73
|
-
const ws = fs.createWriteStream(diskFilePath, {
|
|
74
|
-
encoding: 'utf-8',
|
|
75
|
-
});
|
|
76
|
-
const csvStream = fastcsv.format({ writeHeaders: false, headers: false, delimiter: ',' });
|
|
77
|
-
csvStream.pipe(ws);
|
|
78
|
-
csvStream.write('\ufeff'); // 写入BOM头,解决中文乱码问题
|
|
79
|
-
csvStream.write(this.formatToCsvHeader(this.headerColumns));
|
|
80
|
-
let processed_records = 0;
|
|
81
|
-
try {
|
|
82
|
-
if (typeof totalCount === 'number' && totalCount > 0) {
|
|
83
|
-
const batchCount = Math.ceil(totalCount / pageSize);
|
|
84
|
-
for (let i = 0; i < batchCount; i++) {
|
|
85
|
-
const num = await this.writeExcelBatchData(csvStream, i + 1, pageSize);
|
|
86
|
-
processed_records = processed_records + num;
|
|
87
|
-
const progress = Math.round((processed_records / totalCount) * 100);
|
|
88
|
-
await this.asyncTaskContext.updateTaskStatus({
|
|
89
|
-
processed_records,
|
|
90
|
-
progress,
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.SUCCEEDED;
|
|
95
|
-
}
|
|
96
|
-
catch (error) {
|
|
97
|
-
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.FAILED;
|
|
98
|
-
taskElement.error_message = (0, errorToString_1.errorToString)(error);
|
|
99
|
-
const progress = Math.round((processed_records / totalCount) * 100);
|
|
100
|
-
await this.asyncTaskContext.updateTaskStatus({
|
|
101
|
-
processed_records,
|
|
102
|
-
progress,
|
|
103
|
-
task_status: taskElement.task_status,
|
|
104
|
-
error_message: taskElement.error_message,
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
csvStream.end();
|
|
108
|
-
ws.on('finish', async () => {
|
|
109
|
-
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext finish, taskId=' + taskId);
|
|
110
|
-
const fsStat = await fs2.stat(diskFilePath);
|
|
111
|
-
const output_file_size = fsStat.size;
|
|
112
|
-
this.asyncTaskContext.updateTaskStatus({
|
|
113
|
-
output_file_size,
|
|
114
|
-
});
|
|
115
|
-
});
|
|
116
|
-
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext end, taskId=' + taskId);
|
|
117
|
-
}
|
|
118
|
-
formatToCsvHeader(headerColumns) {
|
|
119
|
-
return headerColumns.map(item => {
|
|
120
|
-
return item.title;
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
async writeExcelBatchData(csvStream, pageNo, pageSize) {
|
|
124
|
-
const dataList = await this.getExcelDataList(pageNo, pageSize);
|
|
125
|
-
for (let i = 0; i < dataList.length; i++) {
|
|
126
|
-
const csvRow = this.formatToCsvRow(dataList[i]);
|
|
127
|
-
csvStream.write(csvRow);
|
|
128
|
-
}
|
|
129
|
-
return dataList.length;
|
|
130
|
-
}
|
|
131
|
-
formatToCsvRow(rowObj) {
|
|
132
|
-
return this.headerColumns.map(obj => {
|
|
133
|
-
const dataIndex = obj.dataIndex;
|
|
134
|
-
const value = _.get(rowObj, dataIndex);
|
|
135
|
-
if (typeof value === 'undefined' || value === null) {
|
|
136
|
-
return '';
|
|
137
|
-
}
|
|
138
|
-
if (typeof value !== 'string') {
|
|
139
|
-
// boolean , number
|
|
140
|
-
return '' + value;
|
|
141
|
-
}
|
|
142
|
-
return value;
|
|
143
|
-
});
|
|
144
|
-
}
|
|
145
|
-
/**
|
|
146
|
-
* 获取文件名
|
|
147
|
-
* @returns 文件名
|
|
148
|
-
*/
|
|
149
|
-
async getExcelFileName() {
|
|
150
|
-
indexRef.current = indexRef.current + 1;
|
|
151
|
-
if (indexRef.current > 100000) {
|
|
152
|
-
indexRef.current = 1;
|
|
153
|
-
}
|
|
154
|
-
const num = `${indexRef.current}`.padStart(10, '0');
|
|
155
|
-
return `export_${Date.now()}_${num}.csv`;
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* 获取Excel的表头
|
|
159
|
-
* @returns
|
|
160
|
-
*/
|
|
161
|
-
async getExcelHeader() {
|
|
162
|
-
return this.excelAsyncTaskHandler.getExcelHeader();
|
|
163
|
-
// const inputParams = parseJsonObject(this.asyncTaskContext?.task?.input_params);
|
|
164
|
-
// if (inputParams && inputParams.appType === 'STD_CRUD') {
|
|
165
|
-
// // const appCode = inputParams.appCode;
|
|
166
|
-
// console.log(this)
|
|
167
|
-
// }
|
|
168
|
-
// return [
|
|
169
|
-
// { title: 'ID', dataIndex: 'id' },
|
|
170
|
-
// { title: '姓名', dataIndex: 'name' },
|
|
171
|
-
// { title: '邮箱', dataIndex: 'email' }
|
|
172
|
-
// ]
|
|
173
|
-
}
|
|
174
|
-
/**
|
|
175
|
-
* 获取文件总数
|
|
176
|
-
*/
|
|
177
|
-
async getTotalCount() {
|
|
178
|
-
const totalCount = await this.excelAsyncTaskHandler.getTotalCount();
|
|
179
|
-
// 最多导出10万条数据
|
|
180
|
-
return Math.min(totalCount, 10 * 10000);
|
|
181
|
-
}
|
|
182
|
-
/**
|
|
183
|
-
* 获取数据内容数组
|
|
184
|
-
* @param pageNo 当前页号,从1开始
|
|
185
|
-
* @param pageSize 每页获取的数量。
|
|
186
|
-
*/
|
|
187
|
-
async getExcelDataList(pageNo, pageSize) {
|
|
188
|
-
return this.excelAsyncTaskHandler.getExcelDataList(pageNo, pageSize);
|
|
189
|
-
// const dataList = [];
|
|
190
|
-
// for (var i = 0; i < pageSize; i++) {
|
|
191
|
-
// dataList.push({ id: i, name: 'nmae' + i, email: 'www.dss@dd.dom' })
|
|
192
|
-
// }
|
|
193
|
-
// return dataList;
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
/**
|
|
197
|
-
* 单例
|
|
198
|
-
*/
|
|
199
|
-
class ExportExcelAsyncTaskHandler {
|
|
200
|
-
async execute(asyncTaskContext) {
|
|
201
|
-
const taskId = _.get(asyncTaskContext, 'task.id');
|
|
202
|
-
console.log('[ExportExcelAsyncTaskHandler] execute, taskId=>' + taskId);
|
|
203
|
-
const res = await schedule_1.ANONYMOUS_CONTEXT.runServiceAtAnonymousContext(async (ctx) => {
|
|
204
|
-
var _a;
|
|
205
|
-
const createdUserSession = (0, functions_1.parseJsonObject)((_a = asyncTaskContext === null || asyncTaskContext === void 0 ? void 0 : asyncTaskContext.task) === null || _a === void 0 ? void 0 : _a.created_user_session);
|
|
206
|
-
ctx.userSession = new userSession_1.UserSessionInfo(createdUserSession, false);
|
|
207
|
-
const task = new ExportExcelAsyncTask(asyncTaskContext, ctx);
|
|
208
|
-
return task.executeWithContext();
|
|
209
|
-
});
|
|
210
|
-
if (res.error) {
|
|
211
|
-
throw res.error;
|
|
212
|
-
}
|
|
213
|
-
return res.result;
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
exports.ExportExcelAsyncTaskHandler = ExportExcelAsyncTaskHandler;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ExportExcelAsyncTaskHandler = void 0;
|
|
4
|
+
const AsyncTaskModel_1 = require("../../../models/AsyncTaskModel");
|
|
5
|
+
const schedule_1 = require("../../../schedule");
|
|
6
|
+
const AsyncTaskModel_2 = require("../../../models/AsyncTaskModel");
|
|
7
|
+
const ExportExcelByStdCrudHandler_1 = require("./ExportExcelByStdCrudHandler");
|
|
8
|
+
const ExportExcelByInnerHttpHandler_1 = require("./ExportExcelByInnerHttpHandler");
|
|
9
|
+
const bizmodels_1 = require("../../../models/bizmodels");
|
|
10
|
+
const _ = require("lodash");
|
|
11
|
+
const fastcsv = require("fast-csv");
|
|
12
|
+
const fs = require("node:fs");
|
|
13
|
+
const fs2 = require("node:fs/promises");
|
|
14
|
+
const path = require("node:path");
|
|
15
|
+
const functions_1 = require("../../../libs/utils/functions");
|
|
16
|
+
const userSession_1 = require("../../../models/userSession");
|
|
17
|
+
const errorToString_1 = require("../../../libs/utils/errorToString");
|
|
18
|
+
const indexRef = { current: 0 };
|
|
19
|
+
async function createFileFolder(distFileFolder) {
|
|
20
|
+
try {
|
|
21
|
+
await fs2.access(distFileFolder);
|
|
22
|
+
}
|
|
23
|
+
catch (e) {
|
|
24
|
+
await fs2.mkdir(distFileFolder, { recursive: true });
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
function getExcelAsyncTaskHandler(asyncTaskContext, ctx) {
|
|
28
|
+
var _a;
|
|
29
|
+
const inputParams = (0, functions_1.parseJsonObject)((_a = asyncTaskContext === null || asyncTaskContext === void 0 ? void 0 : asyncTaskContext.task) === null || _a === void 0 ? void 0 : _a.input_params);
|
|
30
|
+
if (inputParams && inputParams.appType === bizmodels_1.StdCrudExportInputParamsAppType.STD_CRUD) {
|
|
31
|
+
return new ExportExcelByStdCrudHandler_1.ExportExcelByStdCrudHandler(asyncTaskContext, inputParams, ctx);
|
|
32
|
+
}
|
|
33
|
+
if (inputParams && inputParams.appType === bizmodels_1.StdCrudExportInputParamsAppType.INNER_HTTP) {
|
|
34
|
+
return new ExportExcelByInnerHttpHandler_1.ExportExcelByInnerHttpHandler(asyncTaskContext, inputParams, ctx);
|
|
35
|
+
}
|
|
36
|
+
throw new Error('[getExcelAsyncTaskHandler]appType不支持;appType = ' + inputParams.appType);
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* 多实例,每个任务一个实例。
|
|
40
|
+
* 导出EXCEL异步任务:
|
|
41
|
+
*/
|
|
42
|
+
class ExportExcelAsyncTask {
|
|
43
|
+
constructor(asyncTaskContext, ctx) {
|
|
44
|
+
this.asyncTaskContext = asyncTaskContext;
|
|
45
|
+
this.ctx = ctx;
|
|
46
|
+
this.excelAsyncTaskHandler = getExcelAsyncTaskHandler(asyncTaskContext, ctx);
|
|
47
|
+
}
|
|
48
|
+
getDistFileFolder() {
|
|
49
|
+
const app = schedule_1.ANONYMOUS_CONTEXT.getApp();
|
|
50
|
+
const config = app.getConfig();
|
|
51
|
+
const fatcmsExportExcelTmpFilePath = config.fatcmsExportExcelTmpFilePath;
|
|
52
|
+
if (!fatcmsExportExcelTmpFilePath) {
|
|
53
|
+
return path.join(__dirname, '../../tmp');
|
|
54
|
+
}
|
|
55
|
+
return fatcmsExportExcelTmpFilePath;
|
|
56
|
+
}
|
|
57
|
+
async executeWithContext() {
|
|
58
|
+
const taskElement = this.asyncTaskContext.task;
|
|
59
|
+
const taskId = _.get(this.asyncTaskContext, 'task.id');
|
|
60
|
+
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext start, taskId=' + taskId);
|
|
61
|
+
const pageSize = await this.excelAsyncTaskHandler.getPageSize();
|
|
62
|
+
const fileName = await this.getExcelFileName(); // 文件名
|
|
63
|
+
const distFileFolder = this.getDistFileFolder();
|
|
64
|
+
await createFileFolder(distFileFolder);
|
|
65
|
+
const diskFilePath = path.resolve(distFileFolder, fileName); // 磁盘文件路径
|
|
66
|
+
const totalCount = await this.getTotalCount();
|
|
67
|
+
await this.asyncTaskContext.updateTaskStatus({
|
|
68
|
+
output_total_records: totalCount,
|
|
69
|
+
output_file_format: AsyncTaskModel_2.SysAsyncFileFormat.CSV,
|
|
70
|
+
output_file_path: diskFilePath,
|
|
71
|
+
});
|
|
72
|
+
this.headerColumns = await this.getExcelHeader();
|
|
73
|
+
const ws = fs.createWriteStream(diskFilePath, {
|
|
74
|
+
encoding: 'utf-8',
|
|
75
|
+
});
|
|
76
|
+
const csvStream = fastcsv.format({ writeHeaders: false, headers: false, delimiter: ',' });
|
|
77
|
+
csvStream.pipe(ws);
|
|
78
|
+
csvStream.write('\ufeff'); // 写入BOM头,解决中文乱码问题
|
|
79
|
+
csvStream.write(this.formatToCsvHeader(this.headerColumns));
|
|
80
|
+
let processed_records = 0;
|
|
81
|
+
try {
|
|
82
|
+
if (typeof totalCount === 'number' && totalCount > 0) {
|
|
83
|
+
const batchCount = Math.ceil(totalCount / pageSize);
|
|
84
|
+
for (let i = 0; i < batchCount; i++) {
|
|
85
|
+
const num = await this.writeExcelBatchData(csvStream, i + 1, pageSize);
|
|
86
|
+
processed_records = processed_records + num;
|
|
87
|
+
const progress = Math.round((processed_records / totalCount) * 100);
|
|
88
|
+
await this.asyncTaskContext.updateTaskStatus({
|
|
89
|
+
processed_records,
|
|
90
|
+
progress,
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.SUCCEEDED;
|
|
95
|
+
}
|
|
96
|
+
catch (error) {
|
|
97
|
+
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.FAILED;
|
|
98
|
+
taskElement.error_message = (0, errorToString_1.errorToString)(error);
|
|
99
|
+
const progress = Math.round((processed_records / totalCount) * 100);
|
|
100
|
+
await this.asyncTaskContext.updateTaskStatus({
|
|
101
|
+
processed_records,
|
|
102
|
+
progress,
|
|
103
|
+
task_status: taskElement.task_status,
|
|
104
|
+
error_message: taskElement.error_message,
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
csvStream.end();
|
|
108
|
+
ws.on('finish', async () => {
|
|
109
|
+
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext finish, taskId=' + taskId);
|
|
110
|
+
const fsStat = await fs2.stat(diskFilePath);
|
|
111
|
+
const output_file_size = fsStat.size;
|
|
112
|
+
this.asyncTaskContext.updateTaskStatus({
|
|
113
|
+
output_file_size,
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext end, taskId=' + taskId);
|
|
117
|
+
}
|
|
118
|
+
formatToCsvHeader(headerColumns) {
|
|
119
|
+
return headerColumns.map(item => {
|
|
120
|
+
return item.title;
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
async writeExcelBatchData(csvStream, pageNo, pageSize) {
|
|
124
|
+
const dataList = await this.getExcelDataList(pageNo, pageSize);
|
|
125
|
+
for (let i = 0; i < dataList.length; i++) {
|
|
126
|
+
const csvRow = this.formatToCsvRow(dataList[i]);
|
|
127
|
+
csvStream.write(csvRow);
|
|
128
|
+
}
|
|
129
|
+
return dataList.length;
|
|
130
|
+
}
|
|
131
|
+
formatToCsvRow(rowObj) {
|
|
132
|
+
return this.headerColumns.map(obj => {
|
|
133
|
+
const dataIndex = obj.dataIndex;
|
|
134
|
+
const value = _.get(rowObj, dataIndex);
|
|
135
|
+
if (typeof value === 'undefined' || value === null) {
|
|
136
|
+
return '';
|
|
137
|
+
}
|
|
138
|
+
if (typeof value !== 'string') {
|
|
139
|
+
// boolean , number
|
|
140
|
+
return '' + value;
|
|
141
|
+
}
|
|
142
|
+
return value;
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* 获取文件名
|
|
147
|
+
* @returns 文件名
|
|
148
|
+
*/
|
|
149
|
+
async getExcelFileName() {
|
|
150
|
+
indexRef.current = indexRef.current + 1;
|
|
151
|
+
if (indexRef.current > 100000) {
|
|
152
|
+
indexRef.current = 1;
|
|
153
|
+
}
|
|
154
|
+
const num = `${indexRef.current}`.padStart(10, '0');
|
|
155
|
+
return `export_${Date.now()}_${num}.csv`;
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* 获取Excel的表头
|
|
159
|
+
* @returns
|
|
160
|
+
*/
|
|
161
|
+
async getExcelHeader() {
|
|
162
|
+
return this.excelAsyncTaskHandler.getExcelHeader();
|
|
163
|
+
// const inputParams = parseJsonObject(this.asyncTaskContext?.task?.input_params);
|
|
164
|
+
// if (inputParams && inputParams.appType === 'STD_CRUD') {
|
|
165
|
+
// // const appCode = inputParams.appCode;
|
|
166
|
+
// console.log(this)
|
|
167
|
+
// }
|
|
168
|
+
// return [
|
|
169
|
+
// { title: 'ID', dataIndex: 'id' },
|
|
170
|
+
// { title: '姓名', dataIndex: 'name' },
|
|
171
|
+
// { title: '邮箱', dataIndex: 'email' }
|
|
172
|
+
// ]
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* 获取文件总数
|
|
176
|
+
*/
|
|
177
|
+
async getTotalCount() {
|
|
178
|
+
const totalCount = await this.excelAsyncTaskHandler.getTotalCount();
|
|
179
|
+
// 最多导出10万条数据
|
|
180
|
+
return Math.min(totalCount, 10 * 10000);
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* 获取数据内容数组
|
|
184
|
+
* @param pageNo 当前页号,从1开始
|
|
185
|
+
* @param pageSize 每页获取的数量。
|
|
186
|
+
*/
|
|
187
|
+
async getExcelDataList(pageNo, pageSize) {
|
|
188
|
+
return this.excelAsyncTaskHandler.getExcelDataList(pageNo, pageSize);
|
|
189
|
+
// const dataList = [];
|
|
190
|
+
// for (var i = 0; i < pageSize; i++) {
|
|
191
|
+
// dataList.push({ id: i, name: 'nmae' + i, email: 'www.dss@dd.dom' })
|
|
192
|
+
// }
|
|
193
|
+
// return dataList;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* 单例
|
|
198
|
+
*/
|
|
199
|
+
class ExportExcelAsyncTaskHandler {
|
|
200
|
+
async execute(asyncTaskContext) {
|
|
201
|
+
const taskId = _.get(asyncTaskContext, 'task.id');
|
|
202
|
+
console.log('[ExportExcelAsyncTaskHandler] execute, taskId=>' + taskId);
|
|
203
|
+
const res = await schedule_1.ANONYMOUS_CONTEXT.runServiceAtAnonymousContext(async (ctx) => {
|
|
204
|
+
var _a;
|
|
205
|
+
const createdUserSession = (0, functions_1.parseJsonObject)((_a = asyncTaskContext === null || asyncTaskContext === void 0 ? void 0 : asyncTaskContext.task) === null || _a === void 0 ? void 0 : _a.created_user_session);
|
|
206
|
+
ctx.userSession = new userSession_1.UserSessionInfo(createdUserSession, false);
|
|
207
|
+
const task = new ExportExcelAsyncTask(asyncTaskContext, ctx);
|
|
208
|
+
return task.executeWithContext();
|
|
209
|
+
});
|
|
210
|
+
if (res.error) {
|
|
211
|
+
throw res.error;
|
|
212
|
+
}
|
|
213
|
+
return res.result;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
exports.ExportExcelAsyncTaskHandler = ExportExcelAsyncTaskHandler;
|
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
import { IMidwayKoaContext } from '@midwayjs/koa';
|
|
2
|
-
import { IExcelAsyncTaskHandler, IExcelHeaderInfo } from './ExcelInfoModel';
|
|
3
|
-
import { SysAsyncTaskContext } from '../../../models/AsyncTaskModel';
|
|
4
|
-
import { IStdCrudExportInputParams } from '../../../models/bizmodels';
|
|
5
|
-
/**
|
|
6
|
-
* 多实例,每个任务一个实例。
|
|
7
|
-
* 导出Excel。请求任务级别的。
|
|
8
|
-
* 使用内部HTTP接口导出
|
|
9
|
-
*/
|
|
10
|
-
declare class ExportExcelByInnerHttpHandler implements IExcelAsyncTaskHandler {
|
|
11
|
-
protected asyncTaskContext: SysAsyncTaskContext;
|
|
12
|
-
protected ctx: IMidwayKoaContext;
|
|
13
|
-
protected inputParams: IStdCrudExportInputParams;
|
|
14
|
-
protected appCode: string;
|
|
15
|
-
constructor(asyncTaskContext: SysAsyncTaskContext, inputParams: IStdCrudExportInputParams, ctx: IMidwayKoaContext);
|
|
16
|
-
getPageSize(): Promise<number>;
|
|
17
|
-
/**
|
|
18
|
-
* 获取Excel表的表头
|
|
19
|
-
* @returns 表头信息
|
|
20
|
-
*/
|
|
21
|
-
getExcelHeader(): Promise<IExcelHeaderInfo[]>;
|
|
22
|
-
private sendRequest;
|
|
23
|
-
/**
|
|
24
|
-
* 获取要导出的数量总数
|
|
25
|
-
* @returns 数据总量
|
|
26
|
-
*/
|
|
27
|
-
getTotalCount(): Promise<number>;
|
|
28
|
-
/**
|
|
29
|
-
* 获取要导出Excel的数据的内容
|
|
30
|
-
* @param pageNo 页号,从1开始
|
|
31
|
-
* @param pageSize 每页数量
|
|
32
|
-
* @returns
|
|
33
|
-
*/
|
|
34
|
-
getExcelDataList(pageNo: number, pageSize: number): Promise<any[]>;
|
|
35
|
-
}
|
|
36
|
-
export { ExportExcelByInnerHttpHandler };
|
|
1
|
+
import { IMidwayKoaContext } from '@midwayjs/koa';
|
|
2
|
+
import { IExcelAsyncTaskHandler, IExcelHeaderInfo } from './ExcelInfoModel';
|
|
3
|
+
import { SysAsyncTaskContext } from '../../../models/AsyncTaskModel';
|
|
4
|
+
import { IStdCrudExportInputParams } from '../../../models/bizmodels';
|
|
5
|
+
/**
|
|
6
|
+
* 多实例,每个任务一个实例。
|
|
7
|
+
* 导出Excel。请求任务级别的。
|
|
8
|
+
* 使用内部HTTP接口导出
|
|
9
|
+
*/
|
|
10
|
+
declare class ExportExcelByInnerHttpHandler implements IExcelAsyncTaskHandler {
|
|
11
|
+
protected asyncTaskContext: SysAsyncTaskContext;
|
|
12
|
+
protected ctx: IMidwayKoaContext;
|
|
13
|
+
protected inputParams: IStdCrudExportInputParams;
|
|
14
|
+
protected appCode: string;
|
|
15
|
+
constructor(asyncTaskContext: SysAsyncTaskContext, inputParams: IStdCrudExportInputParams, ctx: IMidwayKoaContext);
|
|
16
|
+
getPageSize(): Promise<number>;
|
|
17
|
+
/**
|
|
18
|
+
* 获取Excel表的表头
|
|
19
|
+
* @returns 表头信息
|
|
20
|
+
*/
|
|
21
|
+
getExcelHeader(): Promise<IExcelHeaderInfo[]>;
|
|
22
|
+
private sendRequest;
|
|
23
|
+
/**
|
|
24
|
+
* 获取要导出的数量总数
|
|
25
|
+
* @returns 数据总量
|
|
26
|
+
*/
|
|
27
|
+
getTotalCount(): Promise<number>;
|
|
28
|
+
/**
|
|
29
|
+
* 获取要导出Excel的数据的内容
|
|
30
|
+
* @param pageNo 页号,从1开始
|
|
31
|
+
* @param pageSize 每页数量
|
|
32
|
+
* @returns
|
|
33
|
+
*/
|
|
34
|
+
getExcelDataList(pageNo: number, pageSize: number): Promise<any[]>;
|
|
35
|
+
}
|
|
36
|
+
export { ExportExcelByInnerHttpHandler };
|