midway-fatcms 0.0.1-beta.4 → 0.0.1-beta.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.json +14 -0
- package/.prettierrc.js +4 -0
- package/README.md +7 -0
- package/dist/config/config.default.js +58 -15
- package/dist/config/seed/aeskey.txt +1 -1
- package/dist/configuration.d.ts +1 -0
- package/dist/configuration.js +33 -9
- package/dist/controller/base/BaseApiController.d.ts +7 -1
- package/dist/controller/base/BaseApiController.js +32 -6
- package/dist/controller/gateway/AsyncTaskController.d.ts +20 -0
- package/dist/controller/gateway/AsyncTaskController.js +181 -0
- package/dist/controller/gateway/CrudMtdGatewayController.d.ts +3 -3
- package/dist/controller/gateway/CrudMtdGatewayController.js +9 -6
- package/dist/controller/gateway/DocGatewayController.js +14 -9
- package/dist/controller/gateway/FileController.d.ts +3 -2
- package/dist/controller/gateway/PublicApiController.js +4 -6
- package/dist/controller/gateway/StaticController.d.ts +0 -1
- package/dist/controller/gateway/StaticController.js +40 -39
- package/dist/controller/helpers.controller.d.ts +1 -1
- package/dist/controller/home.controller.js +4 -3
- package/dist/controller/manage/AnyApiMangeApi.js +2 -2
- package/dist/controller/manage/AppLogMangeApi.js +2 -2
- package/dist/controller/manage/AppMangeApi.js +2 -2
- package/dist/controller/manage/AppPageMangeApi.js +2 -2
- package/dist/controller/manage/AppSchemaHistoryApi.js +2 -2
- package/dist/controller/manage/CrudMethodsMangeApi.js +2 -2
- package/dist/controller/manage/CrudStandardDesignApi.d.ts +1 -1
- package/dist/controller/manage/CrudStandardDesignApi.js +86 -83
- package/dist/controller/manage/DataDictManageApi.d.ts +1 -1
- package/dist/controller/manage/DataDictManageApi.js +1 -1
- package/dist/controller/manage/DeployManageApi.d.ts +1 -1
- package/dist/controller/manage/DeployManageApi.js +38 -34
- package/dist/controller/manage/DocLibManageApi.js +2 -2
- package/dist/controller/manage/DocManageApi.js +2 -2
- package/dist/controller/manage/FileManageApi.js +1 -1
- package/dist/controller/manage/LowCodeTplManageApi.js +2 -2
- package/dist/controller/manage/MenuManageApi.js +2 -2
- package/dist/controller/manage/ProxyApiMangeApi.js +2 -2
- package/dist/controller/manage/SuperAdminManageApi.d.ts +2 -2
- package/dist/controller/manage/SuperAdminManageApi.js +12 -8
- package/dist/controller/manage/SysConfigMangeApi.d.ts +1 -1
- package/dist/controller/manage/SysConfigMangeApi.js +8 -6
- package/dist/controller/manage/SystemInfoManageApi.d.ts +1 -1
- package/dist/controller/manage/SystemInfoManageApi.js +7 -1
- package/dist/controller/manage/UserAccountManageApi.d.ts +2 -2
- package/dist/controller/manage/UserAccountManageApi.js +7 -2
- package/dist/controller/manage/WorkbenchMangeApi.js +3 -3
- package/dist/controller/myinfo/AuthController.d.ts +0 -4
- package/dist/controller/myinfo/AuthController.js +1 -54
- package/dist/controller/render/AppRenderController.js +12 -5
- package/dist/controller/test.controller.d.ts +1 -1
- package/dist/controller/test.controller.js +5 -5
- package/dist/index.d.ts +35 -4
- package/dist/index.js +35 -4
- package/dist/libs/crud-pro/CrudPro.d.ts +1 -0
- package/dist/libs/crud-pro/CrudPro.js +5 -0
- package/dist/libs/crud-pro/defaultConfigs.js +2 -0
- package/dist/libs/crud-pro/interfaces.d.ts +7 -1
- package/dist/libs/crud-pro/models/ExecuteContext.d.ts +12 -5
- package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +8 -1
- package/dist/libs/crud-pro/models/ExecuteContextFunc.js +8 -0
- package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +1 -1
- package/dist/libs/crud-pro/models/ResModel.d.ts +16 -0
- package/dist/libs/crud-pro/models/ResModel.js +2 -0
- package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +1 -1
- package/dist/libs/crud-pro/models/Transaction.d.ts +1 -0
- package/dist/libs/crud-pro/models/Transaction.js +7 -0
- package/dist/libs/crud-pro/models/TransactionSqlServer.js +1 -1
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +1 -0
- package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +27 -15
- package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +17 -19
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +1 -1
- package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +10 -12
- package/dist/libs/crud-pro/services/CrudProGenSqlService.js +14 -23
- package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +7 -6
- package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +2 -6
- package/dist/libs/crud-pro/services/CrudProServiceBase.js +15 -3
- package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +1 -0
- package/dist/libs/crud-pro/services/CrudProTableMetaService.js +32 -7
- package/dist/libs/crud-pro/sql.txt +120 -120
- package/dist/libs/crud-pro/utils/DatabaseName.js +24 -3
- package/dist/libs/crud-pro/utils/MixinUtils.js +1 -1
- package/dist/libs/crud-pro/utils/ValidateUtils.js +1 -1
- package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +2 -2
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -0
- package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -0
- package/dist/libs/global-config/global-config.d.ts +45 -0
- package/dist/libs/global-config/global-config.js +33 -0
- package/dist/libs/utils/base64.d.ts +9 -0
- package/dist/libs/utils/base64.js +42 -0
- package/dist/libs/utils/errorToString.d.ts +2 -0
- package/dist/libs/utils/errorToString.js +57 -0
- package/dist/libs/utils/fatcms-request.js +2 -2
- package/dist/libs/utils/functions.d.ts +2 -1
- package/dist/libs/utils/functions.js +6 -1
- package/dist/middleware/forbidden.middleware.js +4 -20
- package/dist/middleware/global.middleware.js +30 -10
- package/dist/middleware/permission.middleware.js +1 -1
- package/dist/models/AsyncTaskModel.d.ts +74 -0
- package/dist/models/AsyncTaskModel.js +31 -0
- package/dist/models/RedisKeys.d.ts +14 -0
- package/dist/models/RedisKeys.js +17 -0
- package/dist/models/SystemEntities.d.ts +8 -1
- package/dist/models/SystemEntities.js +7 -0
- package/dist/models/SystemTables.d.ts +1 -3
- package/dist/models/SystemTables.js +2 -4
- package/dist/models/bizmodels.d.ts +28 -0
- package/dist/models/bizmodels.js +6 -1
- package/dist/schedule/anonymousContext.d.ts +14 -0
- package/dist/schedule/anonymousContext.js +59 -0
- package/dist/schedule/index.d.ts +4 -3
- package/dist/schedule/index.js +8 -67
- package/dist/schedule/runSchedule.d.ts +12 -0
- package/dist/schedule/runSchedule.js +68 -0
- package/dist/schedule/scheduleNames.d.ts +13 -0
- package/dist/schedule/scheduleNames.js +17 -0
- package/dist/service/AuthService.js +8 -5
- package/dist/service/EnumInfoService.js +9 -5
- package/dist/service/FileCenterService.js +13 -9
- package/dist/service/SysConfigService.d.ts +1 -1
- package/dist/service/SysConfigService.js +4 -2
- package/dist/service/UserAccountService.js +10 -6
- package/dist/service/UserSessionService.d.ts +21 -0
- package/dist/service/UserSessionService.js +73 -2
- package/dist/service/VisitStatService.d.ts +1 -1
- package/dist/service/VisitStatService.js +20 -27
- package/dist/service/WorkbenchService.d.ts +33 -0
- package/dist/service/WorkbenchService.js +70 -12
- package/dist/service/anyapi/AnyApiSandboxService.js +12 -12
- package/dist/service/anyapi/AnyApiService.js +4 -2
- package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -0
- package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -0
- package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -0
- package/dist/service/asyncTask/AsyncTaskService.js +34 -0
- package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
- package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -0
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
- package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +139 -0
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
- package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +121 -0
- package/dist/service/base/BaseService.d.ts +12 -0
- package/dist/service/base/BaseService.js +22 -0
- package/dist/service/base/RedisCacheService.d.ts +7 -0
- package/dist/service/base/RedisCacheService.js +7 -0
- package/dist/service/crudstd/CrudStdService.d.ts +8 -1
- package/dist/service/crudstd/CrudStdService.js +63 -6
- package/dist/service/curd/CrudProQuick.d.ts +44 -0
- package/dist/service/curd/CrudProQuick.js +147 -0
- package/dist/service/curd/CurdMixByAccountService.d.ts +4 -4
- package/dist/service/curd/CurdMixByAccountService.js +12 -6
- package/dist/service/curd/CurdMixByDictService.d.ts +4 -4
- package/dist/service/curd/CurdMixByDictService.js +10 -7
- package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +13 -4
- package/dist/service/curd/CurdMixByLinkToCustomService.js +73 -24
- package/dist/service/curd/CurdMixBySysConfigService.d.ts +3 -3
- package/dist/service/curd/CurdMixBySysConfigService.js +4 -2
- package/dist/service/curd/CurdMixByWorkbenchService.d.ts +3 -3
- package/dist/service/curd/CurdMixByWorkbenchService.js +4 -2
- package/dist/service/curd/CurdMixService.d.ts +13 -3
- package/dist/service/curd/CurdMixService.js +26 -2
- package/dist/service/curd/CurdMixUtils.d.ts +27 -4
- package/dist/service/curd/CurdMixUtils.js +115 -41
- package/dist/service/curd/CurdProService.d.ts +3 -10
- package/dist/service/curd/CurdProService.js +36 -148
- package/dist/service/curd/fixCfgModel.d.ts +3 -0
- package/dist/service/curd/fixCfgModel.js +107 -0
- package/dist/service/proxyapi/ProxyApiLoadService.js +7 -4
- package/dist/service/proxyapi/ProxyApiService.d.ts +1 -0
- package/dist/service/proxyapi/ProxyApiService.js +43 -9
- package/dist/views/404_app.html +31 -31
- package/dist/views/404_workbench.html +34 -34
- package/package.json +28 -24
- package/tsconfig.json +32 -0
- package/dist/controller/medstatistic/MedAdminController.d.ts +0 -35
- package/dist/controller/medstatistic/MedAdminController.js +0 -205
- package/dist/controller/medstatistic/MedClientController.d.ts +0 -28
- package/dist/controller/medstatistic/MedClientController.js +0 -188
- package/dist/controller/medstatistic/MedMessageService.d.ts +0 -19
- package/dist/controller/medstatistic/MedMessageService.js +0 -95
- package/dist/controller/medstatistic/MedScoreService.d.ts +0 -21
- package/dist/controller/medstatistic/MedScoreService.js +0 -107
- package/dist/controller/medstatistic/constants.d.ts +0 -32
- package/dist/controller/medstatistic/constants.js +0 -43
- package/src/config/config.default.ts +0 -172
- package/src/config/seed/aeskey.txt +0 -1
- package/src/config/utils.ts +0 -23
- package/src/configuration.ts +0 -83
- package/src/controller/base/BaseApiController.ts +0 -145
- package/src/controller/gateway/AnyApiGatewayController.ts +0 -33
- package/src/controller/gateway/CrudMtdGatewayController.ts +0 -107
- package/src/controller/gateway/CrudStdGatewayController.ts +0 -101
- package/src/controller/gateway/DocGatewayController.ts +0 -165
- package/src/controller/gateway/FileController.ts +0 -110
- package/src/controller/gateway/ProxyApiGatewayController.ts +0 -47
- package/src/controller/gateway/PublicApiController.ts +0 -145
- package/src/controller/gateway/StaticController.ts +0 -328
- package/src/controller/helpers.controller.ts +0 -161
- package/src/controller/home.controller.ts +0 -71
- package/src/controller/manage/AnyApiMangeApi.ts +0 -66
- package/src/controller/manage/AppLogMangeApi.ts +0 -53
- package/src/controller/manage/AppMangeApi.ts +0 -53
- package/src/controller/manage/AppPageMangeApi.ts +0 -52
- package/src/controller/manage/AppSchemaHistoryApi.ts +0 -49
- package/src/controller/manage/CrudMethodsMangeApi.ts +0 -49
- package/src/controller/manage/CrudStandardDesignApi.ts +0 -353
- package/src/controller/manage/DataDictManageApi.ts +0 -78
- package/src/controller/manage/DeployManageApi.ts +0 -179
- package/src/controller/manage/DocLibManageApi.ts +0 -69
- package/src/controller/manage/DocManageApi.ts +0 -99
- package/src/controller/manage/FileManageApi.ts +0 -45
- package/src/controller/manage/LowCodeTplManageApi.ts +0 -52
- package/src/controller/manage/MenuManageApi.ts +0 -63
- package/src/controller/manage/ProxyApiMangeApi.ts +0 -52
- package/src/controller/manage/SuperAdminManageApi.ts +0 -138
- package/src/controller/manage/SysConfigMangeApi.ts +0 -95
- package/src/controller/manage/SystemInfoManageApi.ts +0 -48
- package/src/controller/manage/UserAccountManageApi.ts +0 -88
- package/src/controller/manage/WorkbenchMangeApi.ts +0 -72
- package/src/controller/medstatistic/MedAdminController.ts +0 -221
- package/src/controller/medstatistic/MedClientController.ts +0 -188
- package/src/controller/medstatistic/MedMessageService.ts +0 -89
- package/src/controller/medstatistic/MedScoreService.ts +0 -108
- package/src/controller/medstatistic/constants.ts +0 -63
- package/src/controller/myinfo/AuthController.ts +0 -174
- package/src/controller/myinfo/MyInfoController.ts +0 -32
- package/src/controller/render/AppRenderController.ts +0 -76
- package/src/controller/test.controller.ts +0 -37
- package/src/filter/default.filter.ts +0 -13
- package/src/filter/notfound.filter.ts +0 -10
- package/src/index.ts +0 -71
- package/src/interface.ts +0 -31
- package/src/libs/crud-pro/CrudPro.ts +0 -158
- package/src/libs/crud-pro/defaultConfigs.ts +0 -13
- package/src/libs/crud-pro/exceptions.ts +0 -124
- package/src/libs/crud-pro/interfaces.ts +0 -183
- package/src/libs/crud-pro/models/ExecuteContext.ts +0 -111
- package/src/libs/crud-pro/models/ExecuteContextFunc.ts +0 -86
- package/src/libs/crud-pro/models/FuncContext.ts +0 -21
- package/src/libs/crud-pro/models/RequestCfgModel.ts +0 -141
- package/src/libs/crud-pro/models/RequestModel.ts +0 -141
- package/src/libs/crud-pro/models/ServiceHub.ts +0 -32
- package/src/libs/crud-pro/models/SqlCfgModel.ts +0 -52
- package/src/libs/crud-pro/models/SqlSegArg.ts +0 -13
- package/src/libs/crud-pro/models/Transaction.ts +0 -74
- package/src/libs/crud-pro/models/TransactionMySQL.ts +0 -79
- package/src/libs/crud-pro/models/TransactionPostgres.ts +0 -91
- package/src/libs/crud-pro/models/TransactionSqlServer.ts +0 -107
- package/src/libs/crud-pro/models/keys.ts +0 -159
- package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +0 -75
- package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +0 -128
- package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +0 -279
- package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +0 -60
- package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +0 -180
- package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +0 -373
- package/src/libs/crud-pro/services/CrudProGenSqlService.ts +0 -202
- package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +0 -397
- package/src/libs/crud-pro/services/CrudProServiceBase.ts +0 -98
- package/src/libs/crud-pro/services/CrudProTableMetaService.ts +0 -59
- package/src/libs/crud-pro/services/CurdProServiceHub.ts +0 -92
- package/src/libs/crud-pro/sql.txt +0 -120
- package/src/libs/crud-pro/utils/CompareUtils.ts +0 -23
- package/src/libs/crud-pro/utils/DatabaseName.ts +0 -40
- package/src/libs/crud-pro/utils/DateTimeUtils.ts +0 -20
- package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +0 -64
- package/src/libs/crud-pro/utils/MessageParseUtils.ts +0 -33
- package/src/libs/crud-pro/utils/MixinUtils.ts +0 -285
- package/src/libs/crud-pro/utils/ModelUtils.ts +0 -55
- package/src/libs/crud-pro/utils/MultiKeyMap.ts +0 -72
- package/src/libs/crud-pro/utils/SqlFuncUtils.ts +0 -29
- package/src/libs/crud-pro/utils/TypeUtils.ts +0 -188
- package/src/libs/crud-pro/utils/ValidateUtils.ts +0 -167
- package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +0 -20
- package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +0 -22
- package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +0 -22
- package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +0 -26
- package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +0 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +0 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +0 -129
- package/src/libs/utils/common-dto.ts +0 -52
- package/src/libs/utils/crypto-utils.ts +0 -52
- package/src/libs/utils/fatcms-request.ts +0 -115
- package/src/libs/utils/functions.ts +0 -67
- package/src/libs/utils/ordernum-utils.ts +0 -18
- package/src/libs/utils/parseConfig.ts +0 -62
- package/src/libs/utils/parseCreateSql.ts +0 -91
- package/src/libs/utils/render-utils.ts +0 -184
- package/src/middleware/forbidden.middleware.ts +0 -71
- package/src/middleware/global.middleware.ts +0 -278
- package/src/middleware/permission.middleware.ts +0 -81
- package/src/middleware/tx.middleware.ts +0 -30
- package/src/models/SystemEntities.ts +0 -115
- package/src/models/SystemPerm.ts +0 -105
- package/src/models/SystemTables.ts +0 -30
- package/src/models/bizmodels.ts +0 -89
- package/src/models/contextLogger.ts +0 -132
- package/src/models/devops.ts +0 -17
- package/src/models/userSession.ts +0 -216
- package/src/schedule/index.ts +0 -73
- package/src/service/AuthService.ts +0 -270
- package/src/service/EnumInfoService.ts +0 -129
- package/src/service/FileCenterService.ts +0 -394
- package/src/service/SysConfigService.ts +0 -34
- package/src/service/UserAccountService.ts +0 -100
- package/src/service/UserSessionService.ts +0 -81
- package/src/service/VisitStatService.ts +0 -179
- package/src/service/WorkbenchService.ts +0 -160
- package/src/service/anyapi/AnyApiSandboxService.ts +0 -121
- package/src/service/anyapi/AnyApiService.ts +0 -184
- package/src/service/base/ApiBaseService.ts +0 -42
- package/src/service/base/ApiRateLimiter.ts +0 -59
- package/src/service/base/BaseService.ts +0 -74
- package/src/service/base/RedisCacheService.ts +0 -38
- package/src/service/crudstd/CrudStdActionService.ts +0 -27
- package/src/service/crudstd/CrudStdConstant.ts +0 -62
- package/src/service/crudstd/CrudStdRelationService.ts +0 -78
- package/src/service/crudstd/CrudStdService.ts +0 -188
- package/src/service/curd/CurdMixByAccountService.ts +0 -83
- package/src/service/curd/CurdMixByDictService.ts +0 -113
- package/src/service/curd/CurdMixByLinkToCustomService.ts +0 -167
- package/src/service/curd/CurdMixBySysConfigService.ts +0 -78
- package/src/service/curd/CurdMixByWorkbenchService.ts +0 -68
- package/src/service/curd/CurdMixService.ts +0 -65
- package/src/service/curd/CurdMixUtils.ts +0 -248
- package/src/service/curd/CurdProService.ts +0 -379
- package/src/service/proxyapi/ProxyApiLoadService.ts +0 -165
- package/src/service/proxyapi/ProxyApiService.ts +0 -262
- package/src/service/proxyapi/ProxyApiUtils.ts +0 -32
- package/src/service/proxyapi/RouteHandler.ts +0 -8
- package/src/service/proxyapi/RouteTrie.ts +0 -74
- package/src/service/proxyapi/WeightedRandom.ts +0 -37
- package/src/service/proxyapi/WeightedRoundRobin.ts +0 -44
- package/src/views/404_app.html +0 -31
- package/src/views/404_workbench.html +0 -34
- package/src/views/static/favicon.ico +0 -0
|
@@ -20,6 +20,8 @@ const exceptions_1 = require("../libs/crud-pro/exceptions");
|
|
|
20
20
|
const functions_1 = require("../libs/utils/functions");
|
|
21
21
|
const fatcms_request_1 = require("../libs/utils/fatcms-request");
|
|
22
22
|
const MixinUtils_1 = require("../libs/crud-pro/utils/MixinUtils");
|
|
23
|
+
const global_config_1 = require("../libs/global-config/global-config");
|
|
24
|
+
const AsyncTaskModel_1 = require("../models/AsyncTaskModel");
|
|
23
25
|
//
|
|
24
26
|
// const lruCache = new LRUCache<string, any>({
|
|
25
27
|
// max: 500,
|
|
@@ -37,21 +39,32 @@ let WorkbenchService = class WorkbenchService extends BaseService_1.BaseService
|
|
|
37
39
|
async runBySchedule() {
|
|
38
40
|
await this.getAllWorkbenchInfoMap(true);
|
|
39
41
|
}
|
|
42
|
+
/**
|
|
43
|
+
* 获取所有站点列表
|
|
44
|
+
* @param isForceRefresh 是否强制刷新缓存
|
|
45
|
+
* @returns
|
|
46
|
+
*/
|
|
40
47
|
async getAllWorkbenchInfoList(isForceRefresh) {
|
|
48
|
+
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
41
49
|
let listData = lruCache.get(CACHE_KEY_WORKBENCH_LIST);
|
|
42
50
|
if (!listData || isForceRefresh === true) {
|
|
43
51
|
const reqJson = { condition: {}, pageSize: 1000, limit: 1000 };
|
|
44
52
|
const res = await this.curdProService.executeCrudByCfg(reqJson, {
|
|
45
53
|
sqlTable: SystemTables_1.SystemTables.sys_workbench,
|
|
46
54
|
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY,
|
|
47
|
-
sqlDatabase:
|
|
48
|
-
|
|
55
|
+
sqlDatabase: SystemDbName,
|
|
56
|
+
sqlDbType: SystemDbType,
|
|
49
57
|
});
|
|
50
58
|
listData = res.getResRows();
|
|
51
59
|
lruCache.set(CACHE_KEY_WORKBENCH_LIST, listData);
|
|
52
60
|
}
|
|
53
61
|
return listData;
|
|
54
62
|
}
|
|
63
|
+
/**
|
|
64
|
+
* 获取所有站点列表,以map的形式返回。其中key为站点域名,value为站点信息
|
|
65
|
+
* @param isForceRefresh 是否强制刷新缓存
|
|
66
|
+
* @returns
|
|
67
|
+
*/
|
|
55
68
|
async getAllWorkbenchInfoMap(isForceRefresh) {
|
|
56
69
|
let listData;
|
|
57
70
|
let domainMap = lruCache.get(CACHE_KEY_DOMAIN_MAP);
|
|
@@ -65,6 +78,12 @@ let WorkbenchService = class WorkbenchService extends BaseService_1.BaseService
|
|
|
65
78
|
}
|
|
66
79
|
return domainMap;
|
|
67
80
|
}
|
|
81
|
+
/**
|
|
82
|
+
* 检查站点编码是否匹配
|
|
83
|
+
* @param workbench_code_array 站点编码数组
|
|
84
|
+
* @param workbench_code 站点编码
|
|
85
|
+
* @returns
|
|
86
|
+
*/
|
|
68
87
|
isMatchWorkbenchCode(workbench_code_array, workbench_code) {
|
|
69
88
|
if (workbench_code_array === '*') {
|
|
70
89
|
return true;
|
|
@@ -74,6 +93,30 @@ let WorkbenchService = class WorkbenchService extends BaseService_1.BaseService
|
|
|
74
93
|
.filter(Boolean);
|
|
75
94
|
return supportWorkbenchArray.includes('*') || supportWorkbenchArray.includes(workbench_code);
|
|
76
95
|
}
|
|
96
|
+
/**
|
|
97
|
+
* 根据站点编码获取站点信息
|
|
98
|
+
* @param workbenchCode 站点编码
|
|
99
|
+
* @returns
|
|
100
|
+
*/
|
|
101
|
+
async getWorkbenchInfoByCode(workbenchCode) {
|
|
102
|
+
const list = await this.getAllWorkbenchInfoList();
|
|
103
|
+
for (let i = 0; i < list.length; i++) {
|
|
104
|
+
const workbenchInfo = list[i];
|
|
105
|
+
if (workbenchInfo.workbench_code === workbenchCode) {
|
|
106
|
+
return workbenchInfo;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return null;
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* 根据域名获取站点信息
|
|
113
|
+
* @param host 域名
|
|
114
|
+
* @returns
|
|
115
|
+
*/
|
|
116
|
+
async getWorkbenchInfoByHost(host) {
|
|
117
|
+
const domainMap = await this.getAllWorkbenchInfoMap();
|
|
118
|
+
return domainMap[host];
|
|
119
|
+
}
|
|
77
120
|
/**
|
|
78
121
|
* 获取当前请求的域名所对应的站点信息
|
|
79
122
|
*/
|
|
@@ -84,20 +127,31 @@ let WorkbenchService = class WorkbenchService extends BaseService_1.BaseService
|
|
|
84
127
|
if (!debugWorkbenchCode) {
|
|
85
128
|
throw new exceptions_1.CommonException('本地环境调试时需要使用ModHeader浏览器插件,指定站点编码');
|
|
86
129
|
}
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
130
|
+
return await this.getWorkbenchInfoByCode(debugWorkbenchCode);
|
|
131
|
+
}
|
|
132
|
+
// 内部异步任务,指定了workbench code
|
|
133
|
+
const asyncTaskWorkbenchCode = this.ctx.headers[AsyncTaskModel_1.HEADER_KEY_RUN_BY_ASYNC_TASK_WORKBENCH_CODE];
|
|
134
|
+
if (asyncTaskWorkbenchCode && typeof asyncTaskWorkbenchCode === 'string') {
|
|
135
|
+
return await this.getWorkbenchInfoByCode(asyncTaskWorkbenchCode);
|
|
136
|
+
}
|
|
137
|
+
// 只有一个workbench的场景。对于后台系统。不需要配置域名的场景。
|
|
138
|
+
const fatcmsTargetWorkbenchCode = this.fatcmsTargetWorkbenchCode;
|
|
139
|
+
if (typeof fatcmsTargetWorkbenchCode === 'string' && fatcmsTargetWorkbenchCode.length > 3) {
|
|
140
|
+
return await this.getWorkbenchInfoByCode(fatcmsTargetWorkbenchCode);
|
|
95
141
|
}
|
|
96
142
|
//正式环境: 根据域名获取站点配置
|
|
97
143
|
const host = this.getCurrentHost();
|
|
98
|
-
const
|
|
99
|
-
|
|
144
|
+
const workbenchInfo = await this.getWorkbenchInfoByHost(host);
|
|
145
|
+
if (workbenchInfo) {
|
|
146
|
+
return workbenchInfo;
|
|
147
|
+
}
|
|
148
|
+
// 最后兜底
|
|
149
|
+
return await this.getWorkbenchInfoByHost('*');
|
|
100
150
|
}
|
|
151
|
+
/**
|
|
152
|
+
* 获取当前请求的域名
|
|
153
|
+
* @returns
|
|
154
|
+
*/
|
|
101
155
|
getCurrentHost() {
|
|
102
156
|
const host = this.ctx.request.host;
|
|
103
157
|
if (!host) {
|
|
@@ -147,6 +201,10 @@ __decorate([
|
|
|
147
201
|
(0, core_1.Inject)(),
|
|
148
202
|
__metadata("design:type", CurdProService_1.CurdProService)
|
|
149
203
|
], WorkbenchService.prototype, "curdProService", void 0);
|
|
204
|
+
__decorate([
|
|
205
|
+
(0, core_1.Config)('fatcmsTargetWorkbenchCode'),
|
|
206
|
+
__metadata("design:type", String)
|
|
207
|
+
], WorkbenchService.prototype, "fatcmsTargetWorkbenchCode", void 0);
|
|
150
208
|
WorkbenchService = __decorate([
|
|
151
209
|
(0, core_1.Provide)()
|
|
152
210
|
], WorkbenchService);
|
|
@@ -74,18 +74,18 @@ let AnyApiSandboxService = class AnyApiSandboxService extends BaseService_1.Base
|
|
|
74
74
|
};
|
|
75
75
|
const nextLine100 = new Array(10).fill('\n').join('');
|
|
76
76
|
const bindCode = this.toBindCodeString('httpController', newContext, 'sandbox');
|
|
77
|
-
const code = `
|
|
78
|
-
(async () => {
|
|
79
|
-
${nextLine100}${func_code}; // 必须有一个 class HttpController { async handleRequest(params){} }
|
|
80
|
-
${nextLine100}
|
|
81
|
-
try {
|
|
82
|
-
const httpController = new HttpController();
|
|
83
|
-
${bindCode}
|
|
84
|
-
const res = await httpController.handleRequest(sandbox.allParams.params);
|
|
85
|
-
sandbox.returnSuccess(res);
|
|
86
|
-
} catch (e) {
|
|
87
|
-
sandbox.returnError(e)
|
|
88
|
-
}
|
|
77
|
+
const code = `
|
|
78
|
+
(async () => {
|
|
79
|
+
${nextLine100}${func_code}; // 必须有一个 class HttpController { async handleRequest(params){} }
|
|
80
|
+
${nextLine100}
|
|
81
|
+
try {
|
|
82
|
+
const httpController = new HttpController();
|
|
83
|
+
${bindCode}
|
|
84
|
+
const res = await httpController.handleRequest(sandbox.allParams.params);
|
|
85
|
+
sandbox.returnSuccess(res);
|
|
86
|
+
} catch (e) {
|
|
87
|
+
sandbox.returnError(e)
|
|
88
|
+
}
|
|
89
89
|
})(); `;
|
|
90
90
|
try {
|
|
91
91
|
const script = getCompiledScript(anyApi, code);
|
|
@@ -23,6 +23,7 @@ const MixinUtils_1 = require("../../libs/crud-pro/utils/MixinUtils");
|
|
|
23
23
|
const WorkbenchService_1 = require("../WorkbenchService");
|
|
24
24
|
const ValidateUtils_1 = require("../../libs/crud-pro/utils/ValidateUtils");
|
|
25
25
|
const ApiBaseService_1 = require("../base/ApiBaseService");
|
|
26
|
+
const global_config_1 = require("../../libs/global-config/global-config");
|
|
26
27
|
const lruCache = new lru_cache_1.LRUCache({
|
|
27
28
|
max: 500,
|
|
28
29
|
ttl: 1000 * 60,
|
|
@@ -65,12 +66,13 @@ let AnyApiService = class AnyApiService extends ApiBaseService_1.ApiBaseService
|
|
|
65
66
|
return anyApi;
|
|
66
67
|
}
|
|
67
68
|
async _getAnyApiMethod(methodCode) {
|
|
69
|
+
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
68
70
|
const res = await this.curdMixService.executeCrudByCfg({ condition: { method: methodCode } }, {
|
|
69
71
|
sqlTable: SystemTables_1.SystemTables.sys_anyapi,
|
|
70
72
|
method: `get_sys_anyapi_${methodCode}`,
|
|
71
73
|
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_ONE,
|
|
72
|
-
sqlDatabase:
|
|
73
|
-
|
|
74
|
+
sqlDatabase: SystemDbName,
|
|
75
|
+
sqlDbType: SystemDbType,
|
|
74
76
|
updateCfg: {},
|
|
75
77
|
});
|
|
76
78
|
const obj = res.getOneObj();
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Context } from '@midwayjs/koa';
|
|
2
|
+
import { BaseService } from '../../service/base/BaseService';
|
|
3
|
+
import { IScheduleService } from '../../interface';
|
|
4
|
+
import { ISysAsyncTaskHandler, SysAsyncTaskEntity } from '../../models/AsyncTaskModel';
|
|
5
|
+
declare class AsyncTaskRunner {
|
|
6
|
+
isBusy: boolean;
|
|
7
|
+
taskHandlerMap: Map<string, ISysAsyncTaskHandler>;
|
|
8
|
+
executeTaskList(taskList: SysAsyncTaskEntity[]): Promise<void>;
|
|
9
|
+
private executeTask;
|
|
10
|
+
/**
|
|
11
|
+
* 更新任务状态或任务进度
|
|
12
|
+
* @param taskElement
|
|
13
|
+
* @param updatePartials
|
|
14
|
+
* @private
|
|
15
|
+
*/
|
|
16
|
+
private updateTaskStatus;
|
|
17
|
+
/**
|
|
18
|
+
* 获取当前进程可以处理的任务类型。
|
|
19
|
+
*/
|
|
20
|
+
getHandlerTaskTypeList(): string[];
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* 业务可以扩展
|
|
24
|
+
*/
|
|
25
|
+
export declare const ASYNC_TASK_RUNNER: AsyncTaskRunner;
|
|
26
|
+
export declare class AsyncTaskRunnerService extends BaseService implements IScheduleService {
|
|
27
|
+
protected ctx: Context;
|
|
28
|
+
private curdProService;
|
|
29
|
+
/**
|
|
30
|
+
* 定时任务执行
|
|
31
|
+
*/
|
|
32
|
+
runBySchedule(): Promise<void>;
|
|
33
|
+
/**
|
|
34
|
+
* 更新超时的任务状态
|
|
35
|
+
* @returns
|
|
36
|
+
*/
|
|
37
|
+
private runByScheduleForTimeoutTasks;
|
|
38
|
+
/**
|
|
39
|
+
* 检查是否有新任务。如果有,就从数据库中获取一批任务,放到自己的任务队列里。
|
|
40
|
+
* @returns
|
|
41
|
+
*/
|
|
42
|
+
private runByScheduleForPendingTasks;
|
|
43
|
+
fetchPendingTasks(): Promise<void>;
|
|
44
|
+
/**
|
|
45
|
+
* 是否存在新任务
|
|
46
|
+
* @private
|
|
47
|
+
*/
|
|
48
|
+
private isExistNewTask;
|
|
49
|
+
}
|
|
50
|
+
export {};
|
|
@@ -0,0 +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;
|
|
@@ -0,0 +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;
|
|
@@ -0,0 +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
|
+
}
|