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,287 +1,287 @@
|
|
|
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.AsyncTaskRunnerService = exports.ASYNC_TASK_RUNNER = void 0;
|
|
13
|
-
const moment = require("moment");
|
|
14
|
-
const core_1 = require("@midwayjs/core");
|
|
15
|
-
const BaseService_1 = require("../../service/base/BaseService");
|
|
16
|
-
const CurdProService_1 = require("../../service/curd/CurdProService");
|
|
17
|
-
const AsyncTaskModel_1 = require("../../models/AsyncTaskModel");
|
|
18
|
-
const global_config_1 = require("../../libs/global-config/global-config");
|
|
19
|
-
const SystemTables_1 = require("../../models/SystemTables");
|
|
20
|
-
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
21
|
-
const errorToString_1 = require("../../libs/utils/errorToString");
|
|
22
|
-
const schedule_1 = require("../../schedule");
|
|
23
|
-
const RedisKeys_1 = require("../../models/RedisKeys");
|
|
24
|
-
const functions_1 = require("../../libs/utils/functions");
|
|
25
|
-
const ExportExcelAsyncTaskHandler_1 = require("./handler/ExportExcelAsyncTaskHandler");
|
|
26
|
-
const END_STATUS_LIST = [AsyncTaskModel_1.SysAsyncTaskStatus.PART_SUCCEEDED, AsyncTaskModel_1.SysAsyncTaskStatus.SUCCEEDED, AsyncTaskModel_1.SysAsyncTaskStatus.FAILED, AsyncTaskModel_1.SysAsyncTaskStatus.CANCELLED, AsyncTaskModel_1.SysAsyncTaskStatus.PAUSED];
|
|
27
|
-
class AsyncTaskRunner {
|
|
28
|
-
constructor() {
|
|
29
|
-
this.isBusy = false;
|
|
30
|
-
this.taskHandlerMap = new Map();
|
|
31
|
-
}
|
|
32
|
-
async executeTaskList(taskList) {
|
|
33
|
-
if (!taskList || taskList.length === 0) {
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
this.isBusy = true;
|
|
37
|
-
for (let i = 0; i < taskList.length; i++) {
|
|
38
|
-
const taskElement = taskList[i];
|
|
39
|
-
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.RUNNING;
|
|
40
|
-
try {
|
|
41
|
-
// 1. 更新当前这个任务的状态
|
|
42
|
-
await this.updateTaskStatus(taskElement, {
|
|
43
|
-
task_status: taskElement.task_status,
|
|
44
|
-
started_at: (0, functions_1.getCurrentFullMoment)(),
|
|
45
|
-
updated_at: (0, functions_1.getCurrentFullMoment)(),
|
|
46
|
-
});
|
|
47
|
-
// 任务状态的设置在自定义的执行器里面。
|
|
48
|
-
await this.executeTask(taskElement);
|
|
49
|
-
// 当前不是终止状态,并且没有异常就设置成成功。
|
|
50
|
-
if (!END_STATUS_LIST.includes(taskElement.task_status)) {
|
|
51
|
-
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.SUCCEEDED;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
catch (error) {
|
|
55
|
-
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.FAILED;
|
|
56
|
-
taskElement.error_message = (0, errorToString_1.errorToString)(error);
|
|
57
|
-
}
|
|
58
|
-
try {
|
|
59
|
-
// 2. 更新当前这个任务的状态
|
|
60
|
-
await this.updateTaskStatus(taskElement, {
|
|
61
|
-
task_status: taskElement.task_status,
|
|
62
|
-
error_message: taskElement.error_message,
|
|
63
|
-
updated_at: (0, functions_1.getCurrentFullMoment)(),
|
|
64
|
-
completed_at: (0, functions_1.getCurrentFullMoment)(),
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
catch (error) {
|
|
68
|
-
schedule_1.ANONYMOUS_CONTEXT.getApp().getCoreLogger().error('[AsyncTaskRunner] executeTaskList error', error);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
this.isBusy = false;
|
|
72
|
-
}
|
|
73
|
-
async executeTask(taskElement) {
|
|
74
|
-
const taskType = taskElement.task_type;
|
|
75
|
-
const taskHandler = this.taskHandlerMap.get(taskType);
|
|
76
|
-
if (!taskHandler) {
|
|
77
|
-
throw new Error('TaskHandler not found , taskType = ' + taskType);
|
|
78
|
-
}
|
|
79
|
-
const updateTaskStatus = (updatePartials) => {
|
|
80
|
-
return this.updateTaskStatus(taskElement, updatePartials);
|
|
81
|
-
};
|
|
82
|
-
await taskHandler.execute({ task: taskElement, updateTaskStatus });
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* 更新任务状态或任务进度
|
|
86
|
-
* @param taskElement
|
|
87
|
-
* @param updatePartials
|
|
88
|
-
* @private
|
|
89
|
-
*/
|
|
90
|
-
async updateTaskStatus(taskElement, updatePartials) {
|
|
91
|
-
if (!updatePartials) {
|
|
92
|
-
throw new Error('updatePartials not found');
|
|
93
|
-
}
|
|
94
|
-
return await schedule_1.ANONYMOUS_CONTEXT.runServiceAtAnonymousContext(async (ctx) => {
|
|
95
|
-
const curdProService = await ctx.requestContext.getAsync('curdProService');
|
|
96
|
-
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
97
|
-
// 一定要有一个更新时间字段
|
|
98
|
-
updatePartials.updated_at = (0, functions_1.getCurrentFullMoment)();
|
|
99
|
-
const res = await curdProService.executeCrudByCfg({
|
|
100
|
-
condition: {
|
|
101
|
-
id: taskElement.id,
|
|
102
|
-
},
|
|
103
|
-
data: updatePartials,
|
|
104
|
-
}, {
|
|
105
|
-
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
106
|
-
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE,
|
|
107
|
-
sqlDatabase: SystemDbName,
|
|
108
|
-
sqlDbType: SystemDbType,
|
|
109
|
-
});
|
|
110
|
-
return res.getResModel().affected;
|
|
111
|
-
});
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* 获取当前进程可以处理的任务类型。
|
|
115
|
-
*/
|
|
116
|
-
getHandlerTaskTypeList() {
|
|
117
|
-
const keys = this.taskHandlerMap.keys();
|
|
118
|
-
return [...keys];
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
/**
|
|
122
|
-
* 业务可以扩展
|
|
123
|
-
*/
|
|
124
|
-
exports.ASYNC_TASK_RUNNER = new AsyncTaskRunner();
|
|
125
|
-
//内置的异步任务处理器:EXCEL导出
|
|
126
|
-
exports.ASYNC_TASK_RUNNER.taskHandlerMap.set('EXCEL_EXPORT', new ExportExcelAsyncTaskHandler_1.ExportExcelAsyncTaskHandler());
|
|
127
|
-
/**
|
|
128
|
-
* Redis锁
|
|
129
|
-
*/
|
|
130
|
-
const ASYNC_TASK_LOCK = RedisKeys_1.RedisKeys.ASYNC_TASK_LOCK;
|
|
131
|
-
const ASYNC_TASK_TIMEOUT_LOCK = RedisKeys_1.RedisKeys.ASYNC_TASK_TIMEOUT_LOCK;
|
|
132
|
-
/**
|
|
133
|
-
* 上次检查异步任务的时间点
|
|
134
|
-
*/
|
|
135
|
-
const ASYNC_TASK_RUNTIME_OBJ = {
|
|
136
|
-
LAST_CHECK_ASYNC_TASK_UPDATE_TIME: 0,
|
|
137
|
-
};
|
|
138
|
-
let AsyncTaskRunnerService = class AsyncTaskRunnerService extends BaseService_1.BaseService {
|
|
139
|
-
/**
|
|
140
|
-
* 定时任务执行
|
|
141
|
-
*/
|
|
142
|
-
async runBySchedule() {
|
|
143
|
-
await this.runByScheduleForPendingTasks();
|
|
144
|
-
await this.runByScheduleForTimeoutTasks();
|
|
145
|
-
}
|
|
146
|
-
/**
|
|
147
|
-
* 更新超时的任务状态
|
|
148
|
-
* @returns
|
|
149
|
-
*/
|
|
150
|
-
async runByScheduleForTimeoutTasks() {
|
|
151
|
-
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
152
|
-
// 每隔一小时执行一次,即可。
|
|
153
|
-
const lock = await this.redisService.set(ASYNC_TASK_TIMEOUT_LOCK, 1, 'EX', 60 * 60, 'NX');
|
|
154
|
-
if (lock !== 'OK') {
|
|
155
|
-
return Promise.resolve();
|
|
156
|
-
}
|
|
157
|
-
const timeoutTime = moment().subtract(24, 'hours').format('YYYY-MM-DD HH:mm:ss.SSS');
|
|
158
|
-
await this.curdProService.executeCrudByCfg({
|
|
159
|
-
condition: {
|
|
160
|
-
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.RUNNING,
|
|
161
|
-
updated_at: {
|
|
162
|
-
$lt: timeoutTime,
|
|
163
|
-
},
|
|
164
|
-
},
|
|
165
|
-
data: {
|
|
166
|
-
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.FAILED,
|
|
167
|
-
error_message: '任务超时',
|
|
168
|
-
},
|
|
169
|
-
}, {
|
|
170
|
-
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
171
|
-
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE,
|
|
172
|
-
sqlDatabase: SystemDbName,
|
|
173
|
-
sqlDbType: SystemDbType,
|
|
174
|
-
});
|
|
175
|
-
}
|
|
176
|
-
/**
|
|
177
|
-
* 检查是否有新任务。如果有,就从数据库中获取一批任务,放到自己的任务队列里。
|
|
178
|
-
* @returns
|
|
179
|
-
*/
|
|
180
|
-
async runByScheduleForPendingTasks() {
|
|
181
|
-
// 1. 当前很忙
|
|
182
|
-
if (exports.ASYNC_TASK_RUNNER.isBusy) {
|
|
183
|
-
return Promise.resolve();
|
|
184
|
-
}
|
|
185
|
-
// 2. 发现了新任务
|
|
186
|
-
const isExistNewTask = await this.isExistNewTask();
|
|
187
|
-
if (!isExistNewTask) {
|
|
188
|
-
return Promise.resolve();
|
|
189
|
-
}
|
|
190
|
-
// 这里的过期时间1分钟即可。fetchPendingTasks函数不可能超过一分钟。
|
|
191
|
-
// 因为这里只是从数据库中获取一批任务,放到自己的任务队列里。还没触发执行。
|
|
192
|
-
const lock = await this.redisService.set(ASYNC_TASK_LOCK, 1, 'EX', 60, 'NX');
|
|
193
|
-
if (lock !== 'OK') {
|
|
194
|
-
return Promise.resolve();
|
|
195
|
-
}
|
|
196
|
-
try {
|
|
197
|
-
await this.fetchPendingTasks();
|
|
198
|
-
}
|
|
199
|
-
catch (e) {
|
|
200
|
-
console.error('[AsyncTaskRunnerService] fetchPendingTasks error', (0, errorToString_1.errorToString)(e));
|
|
201
|
-
}
|
|
202
|
-
await this.redisService.del(ASYNC_TASK_LOCK);
|
|
203
|
-
return Promise.resolve();
|
|
204
|
-
}
|
|
205
|
-
async fetchPendingTasks() {
|
|
206
|
-
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
207
|
-
// 只获取本进程能够处理的任务类型。
|
|
208
|
-
const taskTypeList = exports.ASYNC_TASK_RUNNER.getHandlerTaskTypeList();
|
|
209
|
-
if (taskTypeList.length === 0) {
|
|
210
|
-
return Promise.resolve();
|
|
211
|
-
}
|
|
212
|
-
// 查询等待处理的任务。
|
|
213
|
-
const queryRes = await this.curdProService.executeCrudByCfg({
|
|
214
|
-
condition: {
|
|
215
|
-
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.PENDING,
|
|
216
|
-
task_type: {
|
|
217
|
-
$in: taskTypeList,
|
|
218
|
-
},
|
|
219
|
-
},
|
|
220
|
-
orderBy: 'id+',
|
|
221
|
-
limit: 10,
|
|
222
|
-
}, {
|
|
223
|
-
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
224
|
-
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE,
|
|
225
|
-
sqlDatabase: SystemDbName,
|
|
226
|
-
sqlDbType: SystemDbType,
|
|
227
|
-
});
|
|
228
|
-
const taskList = queryRes.getResRows();
|
|
229
|
-
if (taskList.length === 0) {
|
|
230
|
-
return Promise.resolve();
|
|
231
|
-
}
|
|
232
|
-
const taskIds = taskList.map(elem => elem.id).filter(Boolean);
|
|
233
|
-
// 将状态更新为处理中。防止其它进程重复处理。
|
|
234
|
-
await this.curdProService.executeCrudByCfg({
|
|
235
|
-
condition: {
|
|
236
|
-
id: {
|
|
237
|
-
$in: taskIds,
|
|
238
|
-
},
|
|
239
|
-
},
|
|
240
|
-
data: {
|
|
241
|
-
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.RUNNING,
|
|
242
|
-
},
|
|
243
|
-
}, {
|
|
244
|
-
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
245
|
-
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE,
|
|
246
|
-
sqlDatabase: SystemDbName,
|
|
247
|
-
sqlDbType: SystemDbType,
|
|
248
|
-
});
|
|
249
|
-
// 开始执行。
|
|
250
|
-
await exports.ASYNC_TASK_RUNNER.executeTaskList(taskList).then(() => {
|
|
251
|
-
console.log('[AsyncTaskRunnerService] ASYNC_TASK_RUNNER finished taskIds ==> ' + JSON.stringify(taskIds));
|
|
252
|
-
});
|
|
253
|
-
}
|
|
254
|
-
/**
|
|
255
|
-
* 是否存在新任务
|
|
256
|
-
* @private
|
|
257
|
-
*/
|
|
258
|
-
async isExistNewTask() {
|
|
259
|
-
// 刚启动,没有检查过。
|
|
260
|
-
if (!ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME) {
|
|
261
|
-
ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME = Date.now();
|
|
262
|
-
return true;
|
|
263
|
-
}
|
|
264
|
-
//Redis没有任何内容
|
|
265
|
-
const updateTime = await this.redisService.get(RedisKeys_1.RedisKeys.ASYNC_TASK_UPDATE_TIME);
|
|
266
|
-
if (!updateTime) {
|
|
267
|
-
ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME = Date.now();
|
|
268
|
-
return false;
|
|
269
|
-
}
|
|
270
|
-
const updateTimeNumber = Number.parseInt(updateTime, 10);
|
|
271
|
-
const isExistNewTask = updateTimeNumber > ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME;
|
|
272
|
-
ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME = updateTimeNumber;
|
|
273
|
-
return isExistNewTask;
|
|
274
|
-
}
|
|
275
|
-
};
|
|
276
|
-
__decorate([
|
|
277
|
-
(0, core_1.Inject)(),
|
|
278
|
-
__metadata("design:type", Object)
|
|
279
|
-
], AsyncTaskRunnerService.prototype, "ctx", void 0);
|
|
280
|
-
__decorate([
|
|
281
|
-
(0, core_1.Inject)(),
|
|
282
|
-
__metadata("design:type", CurdProService_1.CurdProService)
|
|
283
|
-
], AsyncTaskRunnerService.prototype, "curdProService", void 0);
|
|
284
|
-
AsyncTaskRunnerService = __decorate([
|
|
285
|
-
(0, core_1.Provide)()
|
|
286
|
-
], AsyncTaskRunnerService);
|
|
287
|
-
exports.AsyncTaskRunnerService = AsyncTaskRunnerService;
|
|
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.AsyncTaskRunnerService = exports.ASYNC_TASK_RUNNER = void 0;
|
|
13
|
+
const moment = require("moment");
|
|
14
|
+
const core_1 = require("@midwayjs/core");
|
|
15
|
+
const BaseService_1 = require("../../service/base/BaseService");
|
|
16
|
+
const CurdProService_1 = require("../../service/curd/CurdProService");
|
|
17
|
+
const AsyncTaskModel_1 = require("../../models/AsyncTaskModel");
|
|
18
|
+
const global_config_1 = require("../../libs/global-config/global-config");
|
|
19
|
+
const SystemTables_1 = require("../../models/SystemTables");
|
|
20
|
+
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
21
|
+
const errorToString_1 = require("../../libs/utils/errorToString");
|
|
22
|
+
const schedule_1 = require("../../schedule");
|
|
23
|
+
const RedisKeys_1 = require("../../models/RedisKeys");
|
|
24
|
+
const functions_1 = require("../../libs/utils/functions");
|
|
25
|
+
const ExportExcelAsyncTaskHandler_1 = require("./handler/ExportExcelAsyncTaskHandler");
|
|
26
|
+
const END_STATUS_LIST = [AsyncTaskModel_1.SysAsyncTaskStatus.PART_SUCCEEDED, AsyncTaskModel_1.SysAsyncTaskStatus.SUCCEEDED, AsyncTaskModel_1.SysAsyncTaskStatus.FAILED, AsyncTaskModel_1.SysAsyncTaskStatus.CANCELLED, AsyncTaskModel_1.SysAsyncTaskStatus.PAUSED];
|
|
27
|
+
class AsyncTaskRunner {
|
|
28
|
+
constructor() {
|
|
29
|
+
this.isBusy = false;
|
|
30
|
+
this.taskHandlerMap = new Map();
|
|
31
|
+
}
|
|
32
|
+
async executeTaskList(taskList) {
|
|
33
|
+
if (!taskList || taskList.length === 0) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
this.isBusy = true;
|
|
37
|
+
for (let i = 0; i < taskList.length; i++) {
|
|
38
|
+
const taskElement = taskList[i];
|
|
39
|
+
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.RUNNING;
|
|
40
|
+
try {
|
|
41
|
+
// 1. 更新当前这个任务的状态
|
|
42
|
+
await this.updateTaskStatus(taskElement, {
|
|
43
|
+
task_status: taskElement.task_status,
|
|
44
|
+
started_at: (0, functions_1.getCurrentFullMoment)(),
|
|
45
|
+
updated_at: (0, functions_1.getCurrentFullMoment)(),
|
|
46
|
+
});
|
|
47
|
+
// 任务状态的设置在自定义的执行器里面。
|
|
48
|
+
await this.executeTask(taskElement);
|
|
49
|
+
// 当前不是终止状态,并且没有异常就设置成成功。
|
|
50
|
+
if (!END_STATUS_LIST.includes(taskElement.task_status)) {
|
|
51
|
+
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.SUCCEEDED;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
taskElement.task_status = AsyncTaskModel_1.SysAsyncTaskStatus.FAILED;
|
|
56
|
+
taskElement.error_message = (0, errorToString_1.errorToString)(error);
|
|
57
|
+
}
|
|
58
|
+
try {
|
|
59
|
+
// 2. 更新当前这个任务的状态
|
|
60
|
+
await this.updateTaskStatus(taskElement, {
|
|
61
|
+
task_status: taskElement.task_status,
|
|
62
|
+
error_message: taskElement.error_message,
|
|
63
|
+
updated_at: (0, functions_1.getCurrentFullMoment)(),
|
|
64
|
+
completed_at: (0, functions_1.getCurrentFullMoment)(),
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
catch (error) {
|
|
68
|
+
schedule_1.ANONYMOUS_CONTEXT.getApp().getCoreLogger().error('[AsyncTaskRunner] executeTaskList error', error);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
this.isBusy = false;
|
|
72
|
+
}
|
|
73
|
+
async executeTask(taskElement) {
|
|
74
|
+
const taskType = taskElement.task_type;
|
|
75
|
+
const taskHandler = this.taskHandlerMap.get(taskType);
|
|
76
|
+
if (!taskHandler) {
|
|
77
|
+
throw new Error('TaskHandler not found , taskType = ' + taskType);
|
|
78
|
+
}
|
|
79
|
+
const updateTaskStatus = (updatePartials) => {
|
|
80
|
+
return this.updateTaskStatus(taskElement, updatePartials);
|
|
81
|
+
};
|
|
82
|
+
await taskHandler.execute({ task: taskElement, updateTaskStatus });
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* 更新任务状态或任务进度
|
|
86
|
+
* @param taskElement
|
|
87
|
+
* @param updatePartials
|
|
88
|
+
* @private
|
|
89
|
+
*/
|
|
90
|
+
async updateTaskStatus(taskElement, updatePartials) {
|
|
91
|
+
if (!updatePartials) {
|
|
92
|
+
throw new Error('updatePartials not found');
|
|
93
|
+
}
|
|
94
|
+
return await schedule_1.ANONYMOUS_CONTEXT.runServiceAtAnonymousContext(async (ctx) => {
|
|
95
|
+
const curdProService = await ctx.requestContext.getAsync('curdProService');
|
|
96
|
+
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
97
|
+
// 一定要有一个更新时间字段
|
|
98
|
+
updatePartials.updated_at = (0, functions_1.getCurrentFullMoment)();
|
|
99
|
+
const res = await curdProService.executeCrudByCfg({
|
|
100
|
+
condition: {
|
|
101
|
+
id: taskElement.id,
|
|
102
|
+
},
|
|
103
|
+
data: updatePartials,
|
|
104
|
+
}, {
|
|
105
|
+
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
106
|
+
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE,
|
|
107
|
+
sqlDatabase: SystemDbName,
|
|
108
|
+
sqlDbType: SystemDbType,
|
|
109
|
+
});
|
|
110
|
+
return res.getResModel().affected;
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* 获取当前进程可以处理的任务类型。
|
|
115
|
+
*/
|
|
116
|
+
getHandlerTaskTypeList() {
|
|
117
|
+
const keys = this.taskHandlerMap.keys();
|
|
118
|
+
return [...keys];
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* 业务可以扩展
|
|
123
|
+
*/
|
|
124
|
+
exports.ASYNC_TASK_RUNNER = new AsyncTaskRunner();
|
|
125
|
+
//内置的异步任务处理器:EXCEL导出
|
|
126
|
+
exports.ASYNC_TASK_RUNNER.taskHandlerMap.set('EXCEL_EXPORT', new ExportExcelAsyncTaskHandler_1.ExportExcelAsyncTaskHandler());
|
|
127
|
+
/**
|
|
128
|
+
* Redis锁
|
|
129
|
+
*/
|
|
130
|
+
const ASYNC_TASK_LOCK = RedisKeys_1.RedisKeys.ASYNC_TASK_LOCK;
|
|
131
|
+
const ASYNC_TASK_TIMEOUT_LOCK = RedisKeys_1.RedisKeys.ASYNC_TASK_TIMEOUT_LOCK;
|
|
132
|
+
/**
|
|
133
|
+
* 上次检查异步任务的时间点
|
|
134
|
+
*/
|
|
135
|
+
const ASYNC_TASK_RUNTIME_OBJ = {
|
|
136
|
+
LAST_CHECK_ASYNC_TASK_UPDATE_TIME: 0,
|
|
137
|
+
};
|
|
138
|
+
let AsyncTaskRunnerService = class AsyncTaskRunnerService extends BaseService_1.BaseService {
|
|
139
|
+
/**
|
|
140
|
+
* 定时任务执行
|
|
141
|
+
*/
|
|
142
|
+
async runBySchedule() {
|
|
143
|
+
await this.runByScheduleForPendingTasks();
|
|
144
|
+
await this.runByScheduleForTimeoutTasks();
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* 更新超时的任务状态
|
|
148
|
+
* @returns
|
|
149
|
+
*/
|
|
150
|
+
async runByScheduleForTimeoutTasks() {
|
|
151
|
+
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
152
|
+
// 每隔一小时执行一次,即可。
|
|
153
|
+
const lock = await this.redisService.set(ASYNC_TASK_TIMEOUT_LOCK, 1, 'EX', 60 * 60, 'NX');
|
|
154
|
+
if (lock !== 'OK') {
|
|
155
|
+
return Promise.resolve();
|
|
156
|
+
}
|
|
157
|
+
const timeoutTime = moment().subtract(24, 'hours').format('YYYY-MM-DD HH:mm:ss.SSS');
|
|
158
|
+
await this.curdProService.executeCrudByCfg({
|
|
159
|
+
condition: {
|
|
160
|
+
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.RUNNING,
|
|
161
|
+
updated_at: {
|
|
162
|
+
$lt: timeoutTime,
|
|
163
|
+
},
|
|
164
|
+
},
|
|
165
|
+
data: {
|
|
166
|
+
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.FAILED,
|
|
167
|
+
error_message: '任务超时',
|
|
168
|
+
},
|
|
169
|
+
}, {
|
|
170
|
+
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
171
|
+
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE,
|
|
172
|
+
sqlDatabase: SystemDbName,
|
|
173
|
+
sqlDbType: SystemDbType,
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* 检查是否有新任务。如果有,就从数据库中获取一批任务,放到自己的任务队列里。
|
|
178
|
+
* @returns
|
|
179
|
+
*/
|
|
180
|
+
async runByScheduleForPendingTasks() {
|
|
181
|
+
// 1. 当前很忙
|
|
182
|
+
if (exports.ASYNC_TASK_RUNNER.isBusy) {
|
|
183
|
+
return Promise.resolve();
|
|
184
|
+
}
|
|
185
|
+
// 2. 发现了新任务
|
|
186
|
+
const isExistNewTask = await this.isExistNewTask();
|
|
187
|
+
if (!isExistNewTask) {
|
|
188
|
+
return Promise.resolve();
|
|
189
|
+
}
|
|
190
|
+
// 这里的过期时间1分钟即可。fetchPendingTasks函数不可能超过一分钟。
|
|
191
|
+
// 因为这里只是从数据库中获取一批任务,放到自己的任务队列里。还没触发执行。
|
|
192
|
+
const lock = await this.redisService.set(ASYNC_TASK_LOCK, 1, 'EX', 60, 'NX');
|
|
193
|
+
if (lock !== 'OK') {
|
|
194
|
+
return Promise.resolve();
|
|
195
|
+
}
|
|
196
|
+
try {
|
|
197
|
+
await this.fetchPendingTasks();
|
|
198
|
+
}
|
|
199
|
+
catch (e) {
|
|
200
|
+
console.error('[AsyncTaskRunnerService] fetchPendingTasks error', (0, errorToString_1.errorToString)(e));
|
|
201
|
+
}
|
|
202
|
+
await this.redisService.del(ASYNC_TASK_LOCK);
|
|
203
|
+
return Promise.resolve();
|
|
204
|
+
}
|
|
205
|
+
async fetchPendingTasks() {
|
|
206
|
+
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
207
|
+
// 只获取本进程能够处理的任务类型。
|
|
208
|
+
const taskTypeList = exports.ASYNC_TASK_RUNNER.getHandlerTaskTypeList();
|
|
209
|
+
if (taskTypeList.length === 0) {
|
|
210
|
+
return Promise.resolve();
|
|
211
|
+
}
|
|
212
|
+
// 查询等待处理的任务。
|
|
213
|
+
const queryRes = await this.curdProService.executeCrudByCfg({
|
|
214
|
+
condition: {
|
|
215
|
+
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.PENDING,
|
|
216
|
+
task_type: {
|
|
217
|
+
$in: taskTypeList,
|
|
218
|
+
},
|
|
219
|
+
},
|
|
220
|
+
orderBy: 'id+',
|
|
221
|
+
limit: 10,
|
|
222
|
+
}, {
|
|
223
|
+
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
224
|
+
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE,
|
|
225
|
+
sqlDatabase: SystemDbName,
|
|
226
|
+
sqlDbType: SystemDbType,
|
|
227
|
+
});
|
|
228
|
+
const taskList = queryRes.getResRows();
|
|
229
|
+
if (taskList.length === 0) {
|
|
230
|
+
return Promise.resolve();
|
|
231
|
+
}
|
|
232
|
+
const taskIds = taskList.map(elem => elem.id).filter(Boolean);
|
|
233
|
+
// 将状态更新为处理中。防止其它进程重复处理。
|
|
234
|
+
await this.curdProService.executeCrudByCfg({
|
|
235
|
+
condition: {
|
|
236
|
+
id: {
|
|
237
|
+
$in: taskIds,
|
|
238
|
+
},
|
|
239
|
+
},
|
|
240
|
+
data: {
|
|
241
|
+
task_status: AsyncTaskModel_1.SysAsyncTaskStatus.RUNNING,
|
|
242
|
+
},
|
|
243
|
+
}, {
|
|
244
|
+
sqlTable: SystemTables_1.SystemTables.sys_async_tasks,
|
|
245
|
+
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE,
|
|
246
|
+
sqlDatabase: SystemDbName,
|
|
247
|
+
sqlDbType: SystemDbType,
|
|
248
|
+
});
|
|
249
|
+
// 开始执行。
|
|
250
|
+
await exports.ASYNC_TASK_RUNNER.executeTaskList(taskList).then(() => {
|
|
251
|
+
console.log('[AsyncTaskRunnerService] ASYNC_TASK_RUNNER finished taskIds ==> ' + JSON.stringify(taskIds));
|
|
252
|
+
});
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* 是否存在新任务
|
|
256
|
+
* @private
|
|
257
|
+
*/
|
|
258
|
+
async isExistNewTask() {
|
|
259
|
+
// 刚启动,没有检查过。
|
|
260
|
+
if (!ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME) {
|
|
261
|
+
ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME = Date.now();
|
|
262
|
+
return true;
|
|
263
|
+
}
|
|
264
|
+
//Redis没有任何内容
|
|
265
|
+
const updateTime = await this.redisService.get(RedisKeys_1.RedisKeys.ASYNC_TASK_UPDATE_TIME);
|
|
266
|
+
if (!updateTime) {
|
|
267
|
+
ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME = Date.now();
|
|
268
|
+
return false;
|
|
269
|
+
}
|
|
270
|
+
const updateTimeNumber = Number.parseInt(updateTime, 10);
|
|
271
|
+
const isExistNewTask = updateTimeNumber > ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME;
|
|
272
|
+
ASYNC_TASK_RUNTIME_OBJ.LAST_CHECK_ASYNC_TASK_UPDATE_TIME = updateTimeNumber;
|
|
273
|
+
return isExistNewTask;
|
|
274
|
+
}
|
|
275
|
+
};
|
|
276
|
+
__decorate([
|
|
277
|
+
(0, core_1.Inject)(),
|
|
278
|
+
__metadata("design:type", Object)
|
|
279
|
+
], AsyncTaskRunnerService.prototype, "ctx", void 0);
|
|
280
|
+
__decorate([
|
|
281
|
+
(0, core_1.Inject)(),
|
|
282
|
+
__metadata("design:type", CurdProService_1.CurdProService)
|
|
283
|
+
], AsyncTaskRunnerService.prototype, "curdProService", void 0);
|
|
284
|
+
AsyncTaskRunnerService = __decorate([
|
|
285
|
+
(0, core_1.Provide)()
|
|
286
|
+
], AsyncTaskRunnerService);
|
|
287
|
+
exports.AsyncTaskRunnerService = AsyncTaskRunnerService;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Context } from '@midwayjs/koa';
|
|
2
|
-
import { BaseService } from '../../service/base/BaseService';
|
|
3
|
-
export declare class AsyncTaskService extends BaseService {
|
|
4
|
-
protected ctx: Context;
|
|
5
|
-
startTask(): Promise<void>;
|
|
6
|
-
cancelTask(id: number): Promise<void>;
|
|
7
|
-
}
|
|
1
|
+
import { Context } from '@midwayjs/koa';
|
|
2
|
+
import { BaseService } from '../../service/base/BaseService';
|
|
3
|
+
export declare class AsyncTaskService extends BaseService {
|
|
4
|
+
protected ctx: Context;
|
|
5
|
+
startTask(): Promise<void>;
|
|
6
|
+
cancelTask(id: number): Promise<void>;
|
|
7
|
+
}
|