midway-fatcms 0.0.1-beta.4 → 0.0.1-beta.40
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/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/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.js +28 -7
- package/dist/views/404_app.html +31 -31
- package/dist/views/404_workbench.html +34 -34
- package/package.json +25 -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
|
@@ -0,0 +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 };
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ExportExcelByInnerHttpHandler = void 0;
|
|
4
|
+
const _ = require("lodash");
|
|
5
|
+
const axios_1 = require("axios");
|
|
6
|
+
const AsyncTaskModel_1 = require("../../../models/AsyncTaskModel");
|
|
7
|
+
const schedule_1 = require("../../../schedule");
|
|
8
|
+
const functions_1 = require("../../../libs/utils/functions");
|
|
9
|
+
function pickData(a, key) {
|
|
10
|
+
if (a && typeof a.getResModel === 'function') {
|
|
11
|
+
const s = a.getResModel();
|
|
12
|
+
return s[key];
|
|
13
|
+
}
|
|
14
|
+
if (!a) {
|
|
15
|
+
throw 'ExportExcelByInnerHttpHandler返回数据不存在';
|
|
16
|
+
}
|
|
17
|
+
return _.get(a, `data.${key}`);
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* 多实例,每个任务一个实例。
|
|
21
|
+
* 导出Excel。请求任务级别的。
|
|
22
|
+
* 使用内部HTTP接口导出
|
|
23
|
+
*/
|
|
24
|
+
class ExportExcelByInnerHttpHandler {
|
|
25
|
+
constructor(asyncTaskContext, inputParams, ctx) {
|
|
26
|
+
this.ctx = ctx;
|
|
27
|
+
this.inputParams = inputParams;
|
|
28
|
+
this.asyncTaskContext = asyncTaskContext;
|
|
29
|
+
this.appCode = this.inputParams.appCode;
|
|
30
|
+
}
|
|
31
|
+
async getPageSize() {
|
|
32
|
+
if (typeof this.inputParams.pageSize === 'number') {
|
|
33
|
+
return Math.min(this.inputParams.pageSize, 1000);
|
|
34
|
+
}
|
|
35
|
+
return 1000;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* 获取Excel表的表头
|
|
39
|
+
* @returns 表头信息
|
|
40
|
+
*/
|
|
41
|
+
async getExcelHeader() {
|
|
42
|
+
const columns = this.inputParams.columns;
|
|
43
|
+
if (!columns) {
|
|
44
|
+
throw new Error('导出Excel的表头信息不存在');
|
|
45
|
+
}
|
|
46
|
+
if (!Array.isArray(columns) || columns.length === 0) {
|
|
47
|
+
throw new Error('导出Excel的表头信息不是数组');
|
|
48
|
+
}
|
|
49
|
+
return columns
|
|
50
|
+
.map(cc => {
|
|
51
|
+
let { title, dataIndex } = cc;
|
|
52
|
+
if (!dataIndex) {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
if (!title) {
|
|
56
|
+
title = '字段_' + dataIndex;
|
|
57
|
+
}
|
|
58
|
+
return { title, dataIndex };
|
|
59
|
+
})
|
|
60
|
+
.filter(Boolean);
|
|
61
|
+
}
|
|
62
|
+
async sendRequest(params) {
|
|
63
|
+
const port = schedule_1.ANONYMOUS_CONTEXT.getApp().getConfig().koa.port;
|
|
64
|
+
let queryApi = this.inputParams.innerHttpUrl; // 以斜杠开头
|
|
65
|
+
if (!queryApi.startsWith('/')) {
|
|
66
|
+
queryApi = '/' + queryApi;
|
|
67
|
+
}
|
|
68
|
+
const asyncTaskId = this.asyncTaskContext.task.id;
|
|
69
|
+
const createdUserSession = (0, functions_1.parseJsonObject)(this.asyncTaskContext.task.created_user_session);
|
|
70
|
+
const workbenchCode = createdUserSession.workbenchCode;
|
|
71
|
+
params[AsyncTaskModel_1.HEADER_KEY_RUN_BY_ASYNC_TASK_ID] = asyncTaskId;
|
|
72
|
+
params[AsyncTaskModel_1.HEADER_KEY_RUN_BY_ASYNC_TASK_WORKBENCH_CODE] = workbenchCode;
|
|
73
|
+
const headers = this.inputParams.headers || {};
|
|
74
|
+
headers[AsyncTaskModel_1.HEADER_KEY_RUN_BY_ASYNC_TASK_ID] = asyncTaskId;
|
|
75
|
+
headers[AsyncTaskModel_1.HEADER_KEY_RUN_BY_ASYNC_TASK_WORKBENCH_CODE] = workbenchCode;
|
|
76
|
+
const response = await (0, axios_1.default)({
|
|
77
|
+
method: 'POST',
|
|
78
|
+
url: `http://127.0.0.1:${port}${queryApi}`,
|
|
79
|
+
data: params,
|
|
80
|
+
headers: headers,
|
|
81
|
+
responseType: 'json',
|
|
82
|
+
validateStatus: () => true,
|
|
83
|
+
});
|
|
84
|
+
if (response.status !== 200) {
|
|
85
|
+
throw new Error('导出Excel请求错误失败,状态码:' + response.status);
|
|
86
|
+
}
|
|
87
|
+
return response.data;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* 获取要导出的数量总数
|
|
91
|
+
* @returns 数据总量
|
|
92
|
+
*/
|
|
93
|
+
async getTotalCount() {
|
|
94
|
+
var _a, _b;
|
|
95
|
+
const selectedRowKeys = ((_a = this.inputParams) === null || _a === void 0 ? void 0 : _a.selectedRowKeys) || [];
|
|
96
|
+
if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
|
|
97
|
+
return selectedRowKeys.length;
|
|
98
|
+
}
|
|
99
|
+
const lastQueryParams = (_b = this.inputParams) === null || _b === void 0 ? void 0 : _b.lastQueryParams;
|
|
100
|
+
const res = await this.sendRequest({
|
|
101
|
+
condition: (lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.condition) || {},
|
|
102
|
+
orderBy: lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.orderBy,
|
|
103
|
+
pageSize: 1,
|
|
104
|
+
pageNo: 1,
|
|
105
|
+
});
|
|
106
|
+
return pickData(res, 'total_count');
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* 获取要导出Excel的数据的内容
|
|
110
|
+
* @param pageNo 页号,从1开始
|
|
111
|
+
* @param pageSize 每页数量
|
|
112
|
+
* @returns
|
|
113
|
+
*/
|
|
114
|
+
async getExcelDataList(pageNo, pageSize) {
|
|
115
|
+
var _a, _b;
|
|
116
|
+
const selectedRowKeys = ((_a = this.inputParams) === null || _a === void 0 ? void 0 : _a.selectedRowKeys) || [];
|
|
117
|
+
const lastQueryParams = (_b = this.inputParams) === null || _b === void 0 ? void 0 : _b.lastQueryParams;
|
|
118
|
+
const primaryKey = this.inputParams.primaryKey || 'id';
|
|
119
|
+
const params = {
|
|
120
|
+
condition: (lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.condition) || {},
|
|
121
|
+
pageSize: pageSize,
|
|
122
|
+
pageNo: pageNo,
|
|
123
|
+
orderBy: lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.orderBy,
|
|
124
|
+
};
|
|
125
|
+
if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
|
|
126
|
+
params.condition[primaryKey] = {
|
|
127
|
+
$in: selectedRowKeys,
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
const res = await this.sendRequest({
|
|
131
|
+
condition: (lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.condition) || {},
|
|
132
|
+
orderBy: lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.orderBy,
|
|
133
|
+
pageSize: pageSize,
|
|
134
|
+
pageNo: pageNo,
|
|
135
|
+
});
|
|
136
|
+
return pickData(res, 'rows');
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
exports.ExportExcelByInnerHttpHandler = ExportExcelByInnerHttpHandler;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { IMidwayKoaContext } from '@midwayjs/koa';
|
|
2
|
+
import { IExcelAsyncTaskHandler, IExcelHeaderInfo } from './ExcelInfoModel';
|
|
3
|
+
import { SysAsyncTaskContext } from '../../../models/AsyncTaskModel';
|
|
4
|
+
import { ICrudStdAppInfo, IStdCrudExportInputParams } from '../../../models/bizmodels';
|
|
5
|
+
/**
|
|
6
|
+
* 多实例,每个任务一个实例。
|
|
7
|
+
* 导出Excel。请求任务级别的。
|
|
8
|
+
* 使用标准CtdCrudApp导出
|
|
9
|
+
*/
|
|
10
|
+
declare class ExportExcelByStdCrudHandler implements IExcelAsyncTaskHandler {
|
|
11
|
+
protected asyncTaskContext: SysAsyncTaskContext;
|
|
12
|
+
protected ctx: IMidwayKoaContext;
|
|
13
|
+
protected inputParams: IStdCrudExportInputParams;
|
|
14
|
+
protected appCode: string;
|
|
15
|
+
protected crudStdAppInfo: ICrudStdAppInfo;
|
|
16
|
+
constructor(asyncTaskContext: SysAsyncTaskContext, inputParams: IStdCrudExportInputParams, ctx: IMidwayKoaContext);
|
|
17
|
+
getPageSize(): Promise<number>;
|
|
18
|
+
/**
|
|
19
|
+
* 获取应用信息
|
|
20
|
+
* @returns CrudStdService服务实例
|
|
21
|
+
*/
|
|
22
|
+
private getCrudStdService;
|
|
23
|
+
/**
|
|
24
|
+
* 获取应用的配置信息
|
|
25
|
+
* @returns 应用的配置信息
|
|
26
|
+
*/
|
|
27
|
+
private getCrudStdAppInfo;
|
|
28
|
+
/**
|
|
29
|
+
* 获取Excel表的表头
|
|
30
|
+
* @returns 表头信息
|
|
31
|
+
*/
|
|
32
|
+
getExcelHeader(): Promise<IExcelHeaderInfo[]>;
|
|
33
|
+
/**
|
|
34
|
+
* 获取要导出的数量总数
|
|
35
|
+
* @returns 数据总量
|
|
36
|
+
*/
|
|
37
|
+
getTotalCount(): Promise<number>;
|
|
38
|
+
/**
|
|
39
|
+
* 获取要导出Excel的数据的内容
|
|
40
|
+
* @param pageNo 页号,从1开始
|
|
41
|
+
* @param pageSize 每页数量
|
|
42
|
+
* @returns
|
|
43
|
+
*/
|
|
44
|
+
getExcelDataList(pageNo: number, pageSize: number): Promise<any[]>;
|
|
45
|
+
}
|
|
46
|
+
export { ExportExcelByStdCrudHandler };
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ExportExcelByStdCrudHandler = void 0;
|
|
4
|
+
const _ = require("lodash");
|
|
5
|
+
const CrudStdService_1 = require("../../../service/crudstd/CrudStdService");
|
|
6
|
+
const keys_1 = require("../../../libs/crud-pro/models/keys");
|
|
7
|
+
function pickData(a, key) {
|
|
8
|
+
if (a && typeof a.getResModel === 'function') {
|
|
9
|
+
const s = a.getResModel();
|
|
10
|
+
return s[key];
|
|
11
|
+
}
|
|
12
|
+
if (!a) {
|
|
13
|
+
throw 'executeStdQuery返回数据不存在';
|
|
14
|
+
}
|
|
15
|
+
return _.get(a, `data.${key}`);
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* 多实例,每个任务一个实例。
|
|
19
|
+
* 导出Excel。请求任务级别的。
|
|
20
|
+
* 使用标准CtdCrudApp导出
|
|
21
|
+
*/
|
|
22
|
+
class ExportExcelByStdCrudHandler {
|
|
23
|
+
constructor(asyncTaskContext, inputParams, ctx) {
|
|
24
|
+
this.ctx = ctx;
|
|
25
|
+
this.inputParams = inputParams;
|
|
26
|
+
this.asyncTaskContext = asyncTaskContext;
|
|
27
|
+
this.appCode = this.inputParams.appCode;
|
|
28
|
+
}
|
|
29
|
+
async getPageSize() {
|
|
30
|
+
if (typeof this.inputParams.pageSize === 'number') {
|
|
31
|
+
return Math.min(this.inputParams.pageSize, 1000);
|
|
32
|
+
}
|
|
33
|
+
return 1000;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* 获取应用信息
|
|
37
|
+
* @returns CrudStdService服务实例
|
|
38
|
+
*/
|
|
39
|
+
async getCrudStdService() {
|
|
40
|
+
return await this.ctx.requestContext.getAsync(CrudStdService_1.CrudStdService);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* 获取应用的配置信息
|
|
44
|
+
* @returns 应用的配置信息
|
|
45
|
+
*/
|
|
46
|
+
async getCrudStdAppInfo() {
|
|
47
|
+
if (!this.crudStdAppInfo) {
|
|
48
|
+
const appCode = this.inputParams.appCode;
|
|
49
|
+
if (!appCode) {
|
|
50
|
+
throw new Error('inputParams appCode is required');
|
|
51
|
+
}
|
|
52
|
+
const service = await this.getCrudStdService();
|
|
53
|
+
this.crudStdAppInfo = await service.getParsedCrudStdAppInfo(appCode);
|
|
54
|
+
}
|
|
55
|
+
return this.crudStdAppInfo;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* 获取Excel表的表头
|
|
59
|
+
* @returns 表头信息
|
|
60
|
+
*/
|
|
61
|
+
async getExcelHeader() {
|
|
62
|
+
const crudStdAppInfo = await this.getCrudStdAppInfo();
|
|
63
|
+
const stdCrudCfgObj = crudStdAppInfo.stdCrudCfgObj;
|
|
64
|
+
const tableColumns = stdCrudCfgObj.tableColumns || [];
|
|
65
|
+
return tableColumns.map(cc => {
|
|
66
|
+
return cc;
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* 获取要导出的数量总数
|
|
71
|
+
* @returns 数据总量
|
|
72
|
+
*/
|
|
73
|
+
async getTotalCount() {
|
|
74
|
+
var _a, _b;
|
|
75
|
+
const selectedRowKeys = ((_a = this.inputParams) === null || _a === void 0 ? void 0 : _a.selectedRowKeys) || [];
|
|
76
|
+
if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
|
|
77
|
+
return selectedRowKeys.length;
|
|
78
|
+
}
|
|
79
|
+
const lastQueryParams = (_b = this.inputParams) === null || _b === void 0 ? void 0 : _b.lastQueryParams;
|
|
80
|
+
const crudStdService = await this.getCrudStdService();
|
|
81
|
+
const appCode = this.appCode;
|
|
82
|
+
const params = {
|
|
83
|
+
condition: (lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.condition) || {},
|
|
84
|
+
pageSize: 1,
|
|
85
|
+
pageNo: 1,
|
|
86
|
+
};
|
|
87
|
+
if (!this.ctx.innerHeaders) {
|
|
88
|
+
this.ctx.innerHeaders = {};
|
|
89
|
+
}
|
|
90
|
+
Object.assign(this.ctx.innerHeaders, this.inputParams.headers || {});
|
|
91
|
+
const a = await crudStdService.executeStdQuery(appCode, CrudStdService_1.SPECIAL_SETTING_KEY.QUERY_LIST, params, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
|
|
92
|
+
return pickData(a, 'total_count');
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* 获取要导出Excel的数据的内容
|
|
96
|
+
* @param pageNo 页号,从1开始
|
|
97
|
+
* @param pageSize 每页数量
|
|
98
|
+
* @returns
|
|
99
|
+
*/
|
|
100
|
+
async getExcelDataList(pageNo, pageSize) {
|
|
101
|
+
const selectedRowKeys = this.inputParams.selectedRowKeys || [];
|
|
102
|
+
const primaryKey = this.inputParams.primaryKey || 'id';
|
|
103
|
+
const lastQueryParams = this.inputParams.lastQueryParams;
|
|
104
|
+
const crudStdService = await this.getCrudStdService();
|
|
105
|
+
const appCode = this.appCode;
|
|
106
|
+
const params = {
|
|
107
|
+
condition: (lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.condition) || {},
|
|
108
|
+
pageSize: pageSize,
|
|
109
|
+
pageNo: pageNo,
|
|
110
|
+
orderBy: lastQueryParams === null || lastQueryParams === void 0 ? void 0 : lastQueryParams.orderBy,
|
|
111
|
+
};
|
|
112
|
+
if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
|
|
113
|
+
params.condition[primaryKey] = {
|
|
114
|
+
$in: selectedRowKeys,
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
const a = await crudStdService.executeStdQuery(appCode, CrudStdService_1.SPECIAL_SETTING_KEY.QUERY_LIST, params, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
|
|
118
|
+
return pickData(a, 'rows');
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
exports.ExportExcelByStdCrudHandler = ExportExcelByStdCrudHandler;
|
|
@@ -8,6 +8,18 @@ export declare class BaseService {
|
|
|
8
8
|
protected app: koa.Application;
|
|
9
9
|
protected redisService: RedisService;
|
|
10
10
|
protected ossServiceFactory: OSSServiceFactory;
|
|
11
|
+
/**
|
|
12
|
+
* 请求级别的内存缓存
|
|
13
|
+
* @param key
|
|
14
|
+
* @returns
|
|
15
|
+
*/
|
|
16
|
+
protected getFromCtxCache(key: string): any;
|
|
17
|
+
/**
|
|
18
|
+
* 请求级别的内存缓存
|
|
19
|
+
* @param key
|
|
20
|
+
* @param obj
|
|
21
|
+
*/
|
|
22
|
+
protected setToCtxCache(key: string, obj: any): void;
|
|
11
23
|
/**
|
|
12
24
|
* 用户自己上传的文件,使用私有的bucket。
|
|
13
25
|
* @protected
|
|
@@ -17,6 +17,28 @@ const koa = require("@midwayjs/koa");
|
|
|
17
17
|
const contextLogger_1 = require("../../models/contextLogger");
|
|
18
18
|
const fatcms_request_1 = require("../../libs/utils/fatcms-request");
|
|
19
19
|
let BaseService = class BaseService {
|
|
20
|
+
/**
|
|
21
|
+
* 请求级别的内存缓存
|
|
22
|
+
* @param key
|
|
23
|
+
* @returns
|
|
24
|
+
*/
|
|
25
|
+
getFromCtxCache(key) {
|
|
26
|
+
if (!this.ctx.ctxCacheMap) {
|
|
27
|
+
this.ctx.ctxCacheMap = {};
|
|
28
|
+
}
|
|
29
|
+
return this.ctx.ctxCacheMap[key];
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* 请求级别的内存缓存
|
|
33
|
+
* @param key
|
|
34
|
+
* @param obj
|
|
35
|
+
*/
|
|
36
|
+
setToCtxCache(key, obj) {
|
|
37
|
+
if (!this.ctx.ctxCacheMap) {
|
|
38
|
+
this.ctx.ctxCacheMap = {};
|
|
39
|
+
}
|
|
40
|
+
this.ctx.ctxCacheMap[key] = obj;
|
|
41
|
+
}
|
|
20
42
|
/**
|
|
21
43
|
* 用户自己上传的文件,使用私有的bucket。
|
|
22
44
|
* @protected
|
|
@@ -8,6 +8,13 @@ export declare class RedisCacheService {
|
|
|
8
8
|
protected redisService: RedisService;
|
|
9
9
|
protected ossServiceFactory: OSSServiceFactory;
|
|
10
10
|
getJsonObject(key: string): Promise<any>;
|
|
11
|
+
/**
|
|
12
|
+
* 设置缓存对象
|
|
13
|
+
* @param key
|
|
14
|
+
* @param obj
|
|
15
|
+
* @param expireSecond 过期时间,单位秒
|
|
16
|
+
* @returns
|
|
17
|
+
*/
|
|
11
18
|
setJsonObject(key: string, obj: any, expireSecond: number): Promise<any>;
|
|
12
19
|
removeItem(key: string): Promise<any>;
|
|
13
20
|
}
|
|
@@ -20,6 +20,13 @@ let RedisCacheService = class RedisCacheService {
|
|
|
20
20
|
const str = await this.redisService.get(key);
|
|
21
21
|
return (0, functions_1.parseJsonObject)(str);
|
|
22
22
|
}
|
|
23
|
+
/**
|
|
24
|
+
* 设置缓存对象
|
|
25
|
+
* @param key
|
|
26
|
+
* @param obj
|
|
27
|
+
* @param expireSecond 过期时间,单位秒
|
|
28
|
+
* @returns
|
|
29
|
+
*/
|
|
23
30
|
async setJsonObject(key, obj, expireSecond) {
|
|
24
31
|
const str = JSON.stringify(obj);
|
|
25
32
|
return this.redisService.set(key, str, 'EX', expireSecond);
|
|
@@ -40,11 +40,18 @@ export declare class CrudStdService extends ApiBaseService {
|
|
|
40
40
|
* @private
|
|
41
41
|
*/
|
|
42
42
|
private getCrudStdAppInfo;
|
|
43
|
+
/**
|
|
44
|
+
* 查询APP信息
|
|
45
|
+
* @param appCode
|
|
46
|
+
* @private
|
|
47
|
+
*/
|
|
48
|
+
getParsedCrudStdAppInfo(appCode: string): Promise<ICrudStdAppInfo>;
|
|
43
49
|
/**
|
|
44
50
|
* 查询APP信息
|
|
45
51
|
* @param appCode
|
|
46
52
|
* @private
|
|
47
53
|
*/
|
|
48
|
-
|
|
54
|
+
private getParsedCrudStdAppInfoPrivate;
|
|
49
55
|
private hasOperationPerm;
|
|
56
|
+
private fixDataFieldTypeBySqlTableField;
|
|
50
57
|
}
|
|
@@ -10,6 +10,7 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.CrudStdService = exports.SPECIAL_SETTING_KEY = void 0;
|
|
13
|
+
const _ = require("lodash");
|
|
13
14
|
const core_1 = require("@midwayjs/core");
|
|
14
15
|
const CurdMixService_1 = require("../curd/CurdMixService");
|
|
15
16
|
const keys_1 = require("../../libs/crud-pro/models/keys");
|
|
@@ -18,13 +19,26 @@ const devops_1 = require("../../models/devops");
|
|
|
18
19
|
const SystemTables_1 = require("../../models/SystemTables");
|
|
19
20
|
const CrudStdActionService_1 = require("./CrudStdActionService");
|
|
20
21
|
const CrudStdRelationService_1 = require("./CrudStdRelationService");
|
|
21
|
-
const _ = require("lodash");
|
|
22
22
|
const ApiBaseService_1 = require("../base/ApiBaseService");
|
|
23
23
|
const DatabaseName_1 = require("../../libs/crud-pro/utils/DatabaseName");
|
|
24
|
+
const global_config_1 = require("../../libs/global-config/global-config");
|
|
25
|
+
const MixinUtils_1 = require("../../libs/crud-pro/utils/MixinUtils");
|
|
24
26
|
exports.SPECIAL_SETTING_KEY = {
|
|
25
27
|
QUERY_LIST: 'QUERY_LIST',
|
|
26
28
|
QUERY_ONE: 'QUERY_ONE',
|
|
27
29
|
};
|
|
30
|
+
function getExecuteTableNameBySettingKey(appInfo, settingKey) {
|
|
31
|
+
const stdCrudCfgObj = appInfo.stdCrudCfgObj;
|
|
32
|
+
const actionsMap = appInfo.actionsMap || {};
|
|
33
|
+
const actionCfg = actionsMap[settingKey];
|
|
34
|
+
if (actionCfg) {
|
|
35
|
+
const mainTableName = _.get(actionCfg, 'component.props.mainTableName');
|
|
36
|
+
if (typeof mainTableName === 'string' && mainTableName.trim().length > 0) {
|
|
37
|
+
return mainTableName.trim();
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return stdCrudCfgObj.tableBaseInfo.tableName;
|
|
41
|
+
}
|
|
28
42
|
let CrudStdService = class CrudStdService extends ApiBaseService_1.ApiBaseService {
|
|
29
43
|
/**
|
|
30
44
|
* 执行普通CRUD
|
|
@@ -39,8 +53,8 @@ let CrudStdService = class CrudStdService extends ApiBaseService_1.ApiBaseServic
|
|
|
39
53
|
const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
|
|
40
54
|
const cfgModel = {
|
|
41
55
|
sqlDatabase: dbName,
|
|
42
|
-
|
|
43
|
-
sqlTable:
|
|
56
|
+
sqlDbType: dbType,
|
|
57
|
+
sqlTable: getExecuteTableNameBySettingKey(appInfo, settingKey),
|
|
44
58
|
sqlSimpleName,
|
|
45
59
|
};
|
|
46
60
|
// 接口返回最大值
|
|
@@ -53,6 +67,10 @@ let CrudStdService = class CrudStdService extends ApiBaseService_1.ApiBaseServic
|
|
|
53
67
|
}
|
|
54
68
|
// 根据用户配置,设置关联查询的数据信息。
|
|
55
69
|
await this.crudStdRelationService.addCfgModelColumnsRelation(cfgModel, appInfo);
|
|
70
|
+
// 根据表结构的数据类型,修正数据类型
|
|
71
|
+
await this.fixDataFieldTypeBySqlTableField(params, cfgModel, appInfo, { dbType, dbName });
|
|
72
|
+
// 业务系统自定义的修改cfgModel
|
|
73
|
+
await global_config_1.GLOBAL_STATIC_CONFIG.getConfig().bizUpdateCfgModelForCrudStd(params, cfgModel, appInfo, this.ctx);
|
|
56
74
|
return await this.curdMixService.executeCrudByCfg(params, cfgModel);
|
|
57
75
|
}
|
|
58
76
|
/**
|
|
@@ -112,21 +130,36 @@ let CrudStdService = class CrudStdService extends ApiBaseService_1.ApiBaseServic
|
|
|
112
130
|
* @private
|
|
113
131
|
*/
|
|
114
132
|
async getCrudStdAppInfo(appCode) {
|
|
133
|
+
const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
|
|
115
134
|
this.logInfo('getCrudStdAppInfo', appCode);
|
|
116
135
|
const ss = {
|
|
117
136
|
sqlTable: SystemTables_1.SystemTables.sys_app,
|
|
118
137
|
sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_ONE,
|
|
119
|
-
sqlDatabase:
|
|
120
|
-
|
|
138
|
+
sqlDatabase: SystemDbName,
|
|
139
|
+
sqlDbType: SystemDbType,
|
|
121
140
|
};
|
|
122
141
|
return await this.curdMixService.executeCrudByCfg({ condition: { app_code: appCode } }, ss);
|
|
123
142
|
}
|
|
143
|
+
/**
|
|
144
|
+
* 查询APP信息
|
|
145
|
+
* @param appCode
|
|
146
|
+
* @private
|
|
147
|
+
*/
|
|
148
|
+
async getParsedCrudStdAppInfo(appCode) {
|
|
149
|
+
const cacheKey = "getParsedCrudStdAppInfo:" + appCode;
|
|
150
|
+
let appInfo = this.getFromCtxCache(cacheKey);
|
|
151
|
+
if (!appInfo) {
|
|
152
|
+
appInfo = await this.getParsedCrudStdAppInfoPrivate(appCode);
|
|
153
|
+
this.setToCtxCache(cacheKey, appInfo);
|
|
154
|
+
}
|
|
155
|
+
return appInfo;
|
|
156
|
+
}
|
|
124
157
|
/**
|
|
125
158
|
* 查询APP信息
|
|
126
159
|
* @param appCode
|
|
127
160
|
* @private
|
|
128
161
|
*/
|
|
129
|
-
async
|
|
162
|
+
async getParsedCrudStdAppInfoPrivate(appCode) {
|
|
130
163
|
const a = await this.getCrudStdAppInfo(appCode);
|
|
131
164
|
const { row } = a.getResModel();
|
|
132
165
|
if (!row) {
|
|
@@ -159,6 +192,30 @@ let CrudStdService = class CrudStdService extends ApiBaseService_1.ApiBaseServic
|
|
|
159
192
|
}
|
|
160
193
|
return true; // 无需鉴权
|
|
161
194
|
}
|
|
195
|
+
async fixDataFieldTypeBySqlTableField(params, cfgModel, appInfo, arg3) {
|
|
196
|
+
const tableFields = _.get(appInfo, 'stdCrudCfgObj.tableFields');
|
|
197
|
+
const tableFieldMap = MixinUtils_1.MixinUtils.toMap(tableFields, (e) => {
|
|
198
|
+
return e.fieldIndex;
|
|
199
|
+
});
|
|
200
|
+
if (arg3.dbType === keys_1.SqlDbType.postgres) {
|
|
201
|
+
if (cfgModel.sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_INSERT || cfgModel.sqlSimpleName === keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE) {
|
|
202
|
+
const data = params.data || {};
|
|
203
|
+
const dataKeys = Object.keys(data);
|
|
204
|
+
for (let index = 0; index < dataKeys.length; index++) {
|
|
205
|
+
const dataKey = dataKeys[index];
|
|
206
|
+
const dataValue = data[dataKey];
|
|
207
|
+
const fieldInfo = tableFieldMap[dataKey];
|
|
208
|
+
const fieldType = ('' + _.get(fieldInfo, 'type')).toUpperCase();
|
|
209
|
+
if (fieldType === 'ARRAY') {
|
|
210
|
+
const dataValueArray = (0, functions_1.parseJsonObject)(dataValue);
|
|
211
|
+
if (Array.isArray(dataValueArray)) {
|
|
212
|
+
data[dataKey] = `{${dataValueArray.map(v => `"${v}"`).join(',')}}`;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
}
|
|
162
219
|
};
|
|
163
220
|
__decorate([
|
|
164
221
|
(0, core_1.Inject)(),
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { SqlDbType } from '../../libs/crud-pro/models/keys';
|
|
2
|
+
import { IRequestModel } from '../../libs/crud-pro/interfaces';
|
|
3
|
+
import { IRequestCfgModel2 } from '../../models/bizmodels';
|
|
4
|
+
import { CrudPro } from '../../libs/crud-pro/CrudPro';
|
|
5
|
+
import { ResModelAffected, ResModelStandard } from '../../libs/crud-pro/models/ResModel';
|
|
6
|
+
export declare class CrudProQuick {
|
|
7
|
+
private readonly curdPro;
|
|
8
|
+
private readonly sqlDbType;
|
|
9
|
+
private readonly sqlDatabase;
|
|
10
|
+
private readonly sqlTable?;
|
|
11
|
+
private baseCfgModel;
|
|
12
|
+
constructor(curdPro: CrudPro, sqlDatabase: string, sqlDbType: SqlDbType, sqlTable?: string);
|
|
13
|
+
setBaseCfgModel(baseCfgModel: IRequestCfgModel2): void;
|
|
14
|
+
private executeCrudByCfg;
|
|
15
|
+
/**
|
|
16
|
+
* 随便获取一个。不推荐使用。建议使用getUniqueOne。
|
|
17
|
+
* @deprecated
|
|
18
|
+
* @param reqJson
|
|
19
|
+
* @param sqlTable
|
|
20
|
+
* @returns
|
|
21
|
+
*/
|
|
22
|
+
getOne(reqJson: IRequestModel, sqlTable?: string): Promise<any>;
|
|
23
|
+
/**
|
|
24
|
+
* 期望获取唯一的一个对象,如果数据库中的数量不唯一,则报错。
|
|
25
|
+
* @param reqJson
|
|
26
|
+
* @param sqlTable
|
|
27
|
+
* @returns
|
|
28
|
+
*/
|
|
29
|
+
getUniqueOne(reqJson: IRequestModel, sqlTable?: string): Promise<any>;
|
|
30
|
+
/**
|
|
31
|
+
* 获取数据列表
|
|
32
|
+
* @param reqJson
|
|
33
|
+
* @param sqlTable 数据库表名称
|
|
34
|
+
* @returns
|
|
35
|
+
*/
|
|
36
|
+
getList(reqJson: IRequestModel, sqlTable?: string): Promise<any[]>;
|
|
37
|
+
getListPage(reqJson: IRequestModel, sqlTable?: string): Promise<ResModelStandard>;
|
|
38
|
+
getTotalCount(reqJson: IRequestModel, sqlTable?: string): Promise<number>;
|
|
39
|
+
insertObject(reqJson: IRequestModel, sqlTable?: string): Promise<ResModelAffected>;
|
|
40
|
+
updateObject(reqJson: IRequestModel, sqlTable?: string): Promise<ResModelAffected>;
|
|
41
|
+
insertOrUpdate(reqJson: IRequestModel, sqlTable?: string): Promise<ResModelStandard>;
|
|
42
|
+
deleteObject(reqJson: IRequestModel, sqlTable?: string): Promise<ResModelAffected>;
|
|
43
|
+
executeSQL(executeSql: string, args?: any[]): Promise<any>;
|
|
44
|
+
}
|