midway-fatcms 0.0.1-beta.26 → 0.0.1-beta.29

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.
Files changed (188) hide show
  1. package/dist/config/config.default.js +6 -4
  2. package/dist/controller/home.controller.js +2 -1
  3. package/dist/controller/manage/CrudStandardDesignApi.js +8 -8
  4. package/dist/controller/render/AppRenderController.js +2 -1
  5. package/dist/middleware/global.middleware.js +22 -9
  6. package/dist/models/AsyncTaskModel.d.ts +2 -0
  7. package/dist/models/AsyncTaskModel.js +3 -1
  8. package/dist/models/RedisKeys.d.ts +2 -0
  9. package/dist/models/RedisKeys.js +2 -0
  10. package/dist/models/bizmodels.d.ts +1 -0
  11. package/dist/service/UserSessionService.d.ts +21 -0
  12. package/dist/service/UserSessionService.js +71 -1
  13. package/dist/service/WorkbenchService.d.ts +32 -0
  14. package/dist/service/WorkbenchService.js +54 -11
  15. package/dist/service/anyapi/AnyApiSandboxService.js +12 -12
  16. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +14 -1
  17. package/dist/service/asyncTask/AsyncTaskRunnerService.js +70 -25
  18. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +1 -1
  19. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +11 -2
  20. package/dist/service/base/RedisCacheService.d.ts +7 -0
  21. package/dist/service/base/RedisCacheService.js +7 -0
  22. package/dist/service/crudstd/CrudStdService.d.ts +0 -6
  23. package/dist/service/crudstd/CrudStdService.js +13 -33
  24. package/package.json +1 -5
  25. package/src/config/config.default.ts +0 -207
  26. package/src/config/seed/aeskey.txt +0 -1
  27. package/src/config/utils.ts +0 -22
  28. package/src/configuration.ts +0 -109
  29. package/src/controller/base/BaseApiController.ts +0 -170
  30. package/src/controller/gateway/AnyApiGatewayController.ts +0 -33
  31. package/src/controller/gateway/AsyncTaskController.ts +0 -157
  32. package/src/controller/gateway/CrudMtdGatewayController.ts +0 -111
  33. package/src/controller/gateway/CrudStdGatewayController.ts +0 -101
  34. package/src/controller/gateway/DocGatewayController.ts +0 -173
  35. package/src/controller/gateway/FileController.ts +0 -109
  36. package/src/controller/gateway/ProxyApiGatewayController.ts +0 -47
  37. package/src/controller/gateway/PublicApiController.ts +0 -142
  38. package/src/controller/gateway/StaticController.ts +0 -298
  39. package/src/controller/helpers.controller.ts +0 -161
  40. package/src/controller/home.controller.ts +0 -64
  41. package/src/controller/manage/AnyApiMangeApi.ts +0 -66
  42. package/src/controller/manage/AppLogMangeApi.ts +0 -53
  43. package/src/controller/manage/AppMangeApi.ts +0 -53
  44. package/src/controller/manage/AppPageMangeApi.ts +0 -52
  45. package/src/controller/manage/AppSchemaHistoryApi.ts +0 -49
  46. package/src/controller/manage/CrudMethodsMangeApi.ts +0 -49
  47. package/src/controller/manage/CrudStandardDesignApi.ts +0 -346
  48. package/src/controller/manage/DataDictManageApi.ts +0 -78
  49. package/src/controller/manage/DeployManageApi.ts +0 -175
  50. package/src/controller/manage/DocLibManageApi.ts +0 -69
  51. package/src/controller/manage/DocManageApi.ts +0 -99
  52. package/src/controller/manage/FileManageApi.ts +0 -45
  53. package/src/controller/manage/LowCodeTplManageApi.ts +0 -52
  54. package/src/controller/manage/MenuManageApi.ts +0 -58
  55. package/src/controller/manage/ProxyApiMangeApi.ts +0 -52
  56. package/src/controller/manage/SuperAdminManageApi.ts +0 -139
  57. package/src/controller/manage/SysConfigMangeApi.ts +0 -95
  58. package/src/controller/manage/SystemInfoManageApi.ts +0 -53
  59. package/src/controller/manage/UserAccountManageApi.ts +0 -94
  60. package/src/controller/manage/WorkbenchMangeApi.ts +0 -72
  61. package/src/controller/myinfo/AuthController.ts +0 -108
  62. package/src/controller/myinfo/MyInfoController.ts +0 -32
  63. package/src/controller/render/AppRenderController.ts +0 -79
  64. package/src/controller/test.controller.ts +0 -37
  65. package/src/filter/default.filter.ts +0 -13
  66. package/src/filter/notfound.filter.ts +0 -10
  67. package/src/index.ts +0 -106
  68. package/src/interface.ts +0 -31
  69. package/src/libs/crud-pro/CrudPro.ts +0 -165
  70. package/src/libs/crud-pro/defaultConfigs.ts +0 -15
  71. package/src/libs/crud-pro/exceptions.ts +0 -124
  72. package/src/libs/crud-pro/interfaces.ts +0 -190
  73. package/src/libs/crud-pro/models/ExecuteContext.ts +0 -120
  74. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +0 -96
  75. package/src/libs/crud-pro/models/FuncContext.ts +0 -21
  76. package/src/libs/crud-pro/models/RequestCfgModel.ts +0 -141
  77. package/src/libs/crud-pro/models/RequestModel.ts +0 -141
  78. package/src/libs/crud-pro/models/ResModel.ts +0 -19
  79. package/src/libs/crud-pro/models/ServiceHub.ts +0 -32
  80. package/src/libs/crud-pro/models/SqlCfgModel.ts +0 -52
  81. package/src/libs/crud-pro/models/SqlSegArg.ts +0 -13
  82. package/src/libs/crud-pro/models/Transaction.ts +0 -73
  83. package/src/libs/crud-pro/models/TransactionMySQL.ts +0 -79
  84. package/src/libs/crud-pro/models/TransactionPostgres.ts +0 -91
  85. package/src/libs/crud-pro/models/TransactionSqlServer.ts +0 -102
  86. package/src/libs/crud-pro/models/keys.ts +0 -159
  87. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +0 -83
  88. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +0 -128
  89. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +0 -262
  90. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +0 -60
  91. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +0 -180
  92. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +0 -354
  93. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +0 -185
  94. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +0 -393
  95. package/src/libs/crud-pro/services/CrudProServiceBase.ts +0 -94
  96. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +0 -86
  97. package/src/libs/crud-pro/services/CurdProServiceHub.ts +0 -92
  98. package/src/libs/crud-pro/sql.txt +0 -120
  99. package/src/libs/crud-pro/utils/CompareUtils.ts +0 -23
  100. package/src/libs/crud-pro/utils/DatabaseName.ts +0 -60
  101. package/src/libs/crud-pro/utils/DateTimeUtils.ts +0 -20
  102. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +0 -64
  103. package/src/libs/crud-pro/utils/MessageParseUtils.ts +0 -33
  104. package/src/libs/crud-pro/utils/MixinUtils.ts +0 -285
  105. package/src/libs/crud-pro/utils/ModelUtils.ts +0 -55
  106. package/src/libs/crud-pro/utils/MultiKeyMap.ts +0 -72
  107. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +0 -29
  108. package/src/libs/crud-pro/utils/TypeUtils.ts +0 -188
  109. package/src/libs/crud-pro/utils/ValidateUtils.ts +0 -165
  110. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +0 -20
  111. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +0 -22
  112. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +0 -22
  113. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +0 -26
  114. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +0 -26
  115. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +0 -11
  116. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +0 -11
  117. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +0 -129
  118. package/src/libs/global-config/global-config.ts +0 -78
  119. package/src/libs/utils/common-dto.ts +0 -52
  120. package/src/libs/utils/crypto-utils.ts +0 -50
  121. package/src/libs/utils/errorToString.ts +0 -61
  122. package/src/libs/utils/fatcms-request.ts +0 -103
  123. package/src/libs/utils/functions.ts +0 -73
  124. package/src/libs/utils/ordernum-utils.ts +0 -14
  125. package/src/libs/utils/parseConfig.ts +0 -54
  126. package/src/libs/utils/parseCreateSql.ts +0 -91
  127. package/src/libs/utils/render-utils.ts +0 -184
  128. package/src/middleware/forbidden.middleware.ts +0 -52
  129. package/src/middleware/global.middleware.ts +0 -280
  130. package/src/middleware/permission.middleware.ts +0 -80
  131. package/src/middleware/tx.middleware.ts +0 -30
  132. package/src/models/AsyncTaskModel.ts +0 -82
  133. package/src/models/RedisKeys.ts +0 -13
  134. package/src/models/SystemEntities.ts +0 -115
  135. package/src/models/SystemPerm.ts +0 -105
  136. package/src/models/SystemTables.ts +0 -27
  137. package/src/models/bizmodels.ts +0 -120
  138. package/src/models/contextLogger.ts +0 -132
  139. package/src/models/devops.ts +0 -17
  140. package/src/models/userSession.ts +0 -216
  141. package/src/schedule/anonymousContext.ts +0 -73
  142. package/src/schedule/index.ts +0 -12
  143. package/src/schedule/runSchedule.ts +0 -82
  144. package/src/schedule/scheduleNames.ts +0 -21
  145. package/src/service/AuthService.ts +0 -272
  146. package/src/service/EnumInfoService.ts +0 -130
  147. package/src/service/FileCenterService.ts +0 -395
  148. package/src/service/SysConfigService.ts +0 -37
  149. package/src/service/UserAccountService.ts +0 -107
  150. package/src/service/UserSessionService.ts +0 -78
  151. package/src/service/VisitStatService.ts +0 -166
  152. package/src/service/WorkbenchService.ts +0 -165
  153. package/src/service/anyapi/AnyApiSandboxService.ts +0 -121
  154. package/src/service/anyapi/AnyApiService.ts +0 -186
  155. package/src/service/asyncTask/AsyncTaskRunnerService.ts +0 -266
  156. package/src/service/asyncTask/AsyncTaskService.ts +0 -21
  157. package/src/service/asyncTask/handler/ExcelInfoModel.ts +0 -11
  158. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +0 -245
  159. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +0 -147
  160. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +0 -138
  161. package/src/service/base/ApiBaseService.ts +0 -42
  162. package/src/service/base/ApiRateLimiter.ts +0 -59
  163. package/src/service/base/BaseService.ts +0 -100
  164. package/src/service/base/RedisCacheService.ts +0 -38
  165. package/src/service/crudstd/CrudStdActionService.ts +0 -27
  166. package/src/service/crudstd/CrudStdConstant.ts +0 -62
  167. package/src/service/crudstd/CrudStdRelationService.ts +0 -78
  168. package/src/service/crudstd/CrudStdService.ts +0 -283
  169. package/src/service/curd/CrudProQuick.ts +0 -131
  170. package/src/service/curd/CurdMixByAccountService.ts +0 -90
  171. package/src/service/curd/CurdMixByDictService.ts +0 -114
  172. package/src/service/curd/CurdMixByLinkToCustomService.ts +0 -219
  173. package/src/service/curd/CurdMixBySysConfigService.ts +0 -78
  174. package/src/service/curd/CurdMixByWorkbenchService.ts +0 -71
  175. package/src/service/curd/CurdMixService.ts +0 -97
  176. package/src/service/curd/CurdMixUtils.ts +0 -311
  177. package/src/service/curd/CurdProService.ts +0 -229
  178. package/src/service/curd/fixCfgModel.ts +0 -139
  179. package/src/service/proxyapi/ProxyApiLoadService.ts +0 -174
  180. package/src/service/proxyapi/ProxyApiService.ts +0 -262
  181. package/src/service/proxyapi/ProxyApiUtils.ts +0 -32
  182. package/src/service/proxyapi/RouteHandler.ts +0 -8
  183. package/src/service/proxyapi/RouteTrie.ts +0 -74
  184. package/src/service/proxyapi/WeightedRandom.ts +0 -37
  185. package/src/service/proxyapi/WeightedRoundRobin.ts +0 -44
  186. package/src/views/404_app.html +0 -31
  187. package/src/views/404_workbench.html +0 -34
  188. package/src/views/static/favicon.ico +0 -0
@@ -1,109 +0,0 @@
1
- import { Configuration, App } from '@midwayjs/core';
2
- import * as koa from '@midwayjs/koa';
3
- import * as validate from '@midwayjs/validate';
4
- import * as info from '@midwayjs/info';
5
- import * as oss from '@midwayjs/oss';
6
- import * as upload from '@midwayjs/upload';
7
- import * as view from '@midwayjs/view-ejs';
8
- import * as redis from '@midwayjs/redis';
9
- import * as crossDomain from '@midwayjs/cross-domain';
10
- import * as _ from 'lodash';
11
- import { join } from 'path';
12
- // import { DefaultErrorFilter } from './filter/default.filter';
13
- // import { NotFoundFilter } from './filter/notfound.filter';
14
- import { GlobalMiddleware } from './middleware/global.middleware';
15
- import { ForbiddenMiddleware } from './middleware/forbidden.middleware';
16
- import { SCHEDULE_QUEUE, ANONYMOUS_CONTEXT, INNER_SCHEDULE_INTERVAL } from './schedule';
17
- import { privateAES } from './libs/utils/crypto-utils';
18
-
19
- @Configuration({
20
- // namespace: 'fatcms',
21
- imports: [
22
- koa,
23
- validate,
24
- oss,
25
- upload,
26
- view,
27
- crossDomain,
28
- redis,
29
- {
30
- component: info,
31
- },
32
- ],
33
- importConfigs: [join(__dirname, './config')],
34
- })
35
- export class ContainerLifeCycle {
36
- @App()
37
- app: koa.Application;
38
-
39
- async onConfigLoad(): Promise<any> {
40
- const config = this.app.getConfig();
41
- const logger = this.app.getLogger();
42
- const encryptedFieldList: string[] = config.encryptedFieldList || [];
43
- const newConfig = {};
44
-
45
- for (let i = 0; i < encryptedFieldList.length; i++) {
46
- const field = encryptedFieldList[i];
47
- try {
48
- const encryptedValue = _.get(config, field);
49
-
50
- if (encryptedValue && typeof encryptedValue === 'string') {
51
- const newInput = await privateAES.time_decrypt_base64_utf8(encryptedValue);
52
- _.set(newConfig, field, newInput);
53
- }
54
- } catch (e) {
55
- logger.error('ContainerLifeCycle ==> onConfigLoad 解密配置字段失败: ' + field);
56
- }
57
- }
58
-
59
- return newConfig;
60
- }
61
-
62
- async onReady() {
63
- /**
64
- * 让ANONYMOUS_CONTEXT获取app对象
65
- */
66
- ANONYMOUS_CONTEXT.setApp(this.app);
67
-
68
- /**
69
- * 启动定时任务
70
- */
71
- await this.startScheduleOnReady();
72
-
73
- // add middleware
74
- this.app.useMiddleware(ForbiddenMiddleware);
75
- this.app.useMiddleware(GlobalMiddleware);
76
-
77
- // add filter
78
- // this.app.useFilter([NotFoundFilter, DefaultErrorFilter]);
79
- }
80
-
81
- private async startScheduleOnReady() {
82
- const logger = this.app.getLogger();
83
- const config = this.app.getConfig();
84
- const fatcmsScheduleService: boolean | any = config.fatcmsScheduleService;
85
-
86
- // 关闭定时任务
87
- if (fatcmsScheduleService === false || fatcmsScheduleService === null) {
88
- return;
89
- }
90
-
91
- let scheduleIntervalCfg = INNER_SCHEDULE_INTERVAL;
92
- if (typeof fatcmsScheduleService === 'object') {
93
- scheduleIntervalCfg = fatcmsScheduleService;
94
- }
95
-
96
- const keys = Object.keys(scheduleIntervalCfg);
97
- for (let i = 0; i < keys.length; i++) {
98
- const service = keys[i];
99
- const interval = scheduleIntervalCfg[service];
100
- if (typeof interval !== 'number') {
101
- throw new Error('Invalid scheduleIntervalCfg ' + service + ', interval must be a number');
102
- }
103
- SCHEDULE_QUEUE.setScheduleTask(service, interval);
104
- }
105
-
106
- await SCHEDULE_QUEUE.startScheduleLoop();
107
- logger.info('ContainerLifeCycle ==> onReady 启动定时任务 : ' + JSON.stringify(scheduleIntervalCfg));
108
- }
109
- }
@@ -1,170 +0,0 @@
1
- import { Controller, Inject } from '@midwayjs/core';
2
- import { Context } from '@midwayjs/koa';
3
- import { CurdMixService } from '@/service/curd/CurdMixService';
4
- import { IFuncCfgModel, IRequestCfgModel, IValidatorCfgItem } from '@/libs/crud-pro/interfaces';
5
- import { KeyOfCrudTypes, KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
6
- import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
7
- import { UserAccountService } from '@/service/UserAccountService';
8
- import { RelatedType } from '@/service/curd/CurdMixUtils';
9
- import { BaseService } from '@/service/base/BaseService';
10
- import * as moment from 'moment';
11
- import { CommonException } from '@/libs/crud-pro/exceptions';
12
- import { RedisKeys } from '@/models/RedisKeys';
13
-
14
- export interface IExecuteSimpleSqlParams {
15
- updateCfg?: Record<string, IFuncCfgModel>;
16
- allowCfg?: Record<string, string[]>;
17
- rejectCfg?: Record<string, string[]>;
18
- validateCfg?: Record<string, IValidatorCfgItem[]>;
19
- columns?: string | string[]; // ..."columns": "id,name,age,sex,addr",
20
- }
21
-
22
- @Controller('/api/BaseApiController')
23
- export class BaseApiController extends BaseService {
24
- @Inject()
25
- protected ctx: Context;
26
-
27
- @Inject()
28
- protected curdMixService: CurdMixService;
29
-
30
- @Inject()
31
- protected userAccountService: UserAccountService;
32
-
33
- /**
34
- * 检查用户是否在指定时间内重复执行了某个操作
35
- * @param actionCode 操作编码
36
- * @param limitSecond 限制时间,单位:秒
37
- */
38
- protected async checkUserActionTimeLimit(actionCode: string, limitSecond = 60) {
39
- const userSessionInfo = this.getUserSessionInfo();
40
- if (!userSessionInfo) {
41
- throw new CommonException('USER_SESSION_INFO_IS_NOT_EXIST', '用户会话信息不存在');
42
- }
43
- const key = `${RedisKeys.USER_ACTION_TIME_LIMIT_PREFIX}${userSessionInfo.sessionId}_${actionCode}`;
44
- const lock = await this.redisService.set(key, 1, 'EX', limitSecond, 'NX');
45
- if (lock !== 'OK') {
46
- throw new CommonException('TOO_MANY_REQUESTS_PLEASE_WAIT', `您操作太频繁了,请${limitSecond}秒后再试`);
47
- }
48
- }
49
-
50
- protected getUserSessionInfo() {
51
- if (!this.ctx.userSession) {
52
- return null;
53
- }
54
- return this.ctx.userSession.getSessionInfo();
55
- }
56
-
57
- async executeSysSQL(executeSql: string, executeSqlArgs: any[]) {
58
- const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
59
- return await this.curdMixService.executeSQL({
60
- executeSql: executeSql,
61
- executeSqlArgs: executeSqlArgs,
62
- sqlDatabase: SystemDbName,
63
- sqlDbType: SystemDbType,
64
- crudType: KeyOfCrudTypes.SYS_QUERY,
65
- });
66
- }
67
-
68
- /**
69
- * 查询sys表中的SQL语句。sys表的表结构都是标准的。
70
- * @param sqlTable
71
- * @param sqlSimpleName
72
- * @param params
73
- * @protected
74
- */
75
- protected async executeSysSimpleSQL(sqlTable: string, sqlSimpleName: KeysOfSimpleSQL, params?: IExecuteSimpleSqlParams) {
76
- const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
77
- const body = this.ctx.request.body as any;
78
- const req = this.ctx.req;
79
- const cfgModel: IRequestCfgModel = {
80
- method: `${req.method}:${req.url}`,
81
- sqlTable,
82
- sqlSimpleName,
83
- sqlDatabase: SystemDbName,
84
- sqlDbType: SystemDbType,
85
- updateCfg: {},
86
- };
87
-
88
- if (params && typeof params === 'object') {
89
- Object.assign(cfgModel, params);
90
- }
91
-
92
- //自动关联用户基本信息
93
- this.addAccountBasicInfoCfgModel(cfgModel);
94
-
95
- //自动关联工作台基本信息
96
- this.addWorkbenchBasicInfoCfgModel(cfgModel);
97
-
98
- //sys系统表都是标准的,都有modified_at字段。
99
- if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_UPDATE && body.data) {
100
- body.data['modified_at'] = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss.SSS');
101
- }
102
-
103
- return await this.curdMixService.executeCrudByCfg(body, cfgModel);
104
- }
105
-
106
- protected get sysDBUtil() {
107
- const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
108
- return this.curdMixService.getBbUtil(SystemDbName, SystemDbType);
109
- }
110
-
111
- private addAccountBasicInfoCfgModel(cfgModel: IRequestCfgModel) {
112
- let columnsRelation = cfgModel.columnsRelation;
113
- if (!columnsRelation) {
114
- columnsRelation = [];
115
- cfgModel.columnsRelation = columnsRelation;
116
- }
117
- let createdByRelation = columnsRelation.find(s => s.relatedType === RelatedType.accountBasic && s.sourceColumn === 'created_by');
118
- if (!createdByRelation) {
119
- createdByRelation = {
120
- relatedType: RelatedType.accountBasic,
121
- sourceColumn: 'created_by',
122
- targetColumns: [], // 使用默认
123
- };
124
- columnsRelation.push(createdByRelation);
125
- }
126
-
127
- let modifiedByRelation = columnsRelation.find(s => s.relatedType === RelatedType.accountBasic && s.sourceColumn === 'modified_by');
128
- if (!modifiedByRelation) {
129
- modifiedByRelation = {
130
- relatedType: RelatedType.accountBasic,
131
- sourceColumn: 'modified_by',
132
- targetColumns: [], // 使用默认
133
- };
134
- columnsRelation.push(modifiedByRelation);
135
- }
136
- }
137
-
138
- private addWorkbenchBasicInfoCfgModel(cfgModel: IRequestCfgModel) {
139
- let columnsRelation = cfgModel.columnsRelation;
140
- if (!columnsRelation) {
141
- columnsRelation = [];
142
- cfgModel.columnsRelation = columnsRelation;
143
- }
144
- let createdByRelation = columnsRelation.find(s => s.relatedType === RelatedType.workbenchBasic && s.sourceColumn === 'workbench_code');
145
- if (!createdByRelation) {
146
- createdByRelation = {
147
- relatedType: RelatedType.workbenchBasic,
148
- sourceColumn: 'workbench_code',
149
- targetColumns: [
150
- { from: 'workbench_domain', to: 'workbench_info.workbench_domain' },
151
- { from: 'workbench_name', to: 'workbench_info.workbench_name' },
152
- ],
153
- };
154
- columnsRelation.push(createdByRelation);
155
- }
156
-
157
- let createdByRelation2 = columnsRelation.find(s => s.relatedType === RelatedType.workbenchBasic && s.sourceColumn === 'workbench_code_array');
158
- if (!createdByRelation2) {
159
- createdByRelation2 = {
160
- relatedType: RelatedType.workbenchBasic,
161
- sourceColumn: 'workbench_code_array',
162
- targetColumns: [
163
- { from: 'workbench_domain', to: 'workbench_info_array[$ARRAY_INDEX].workbench_domain' },
164
- { from: 'workbench_name', to: 'workbench_info_array[$ARRAY_INDEX].workbench_name' },
165
- ],
166
- };
167
- columnsRelation.push(createdByRelation2);
168
- }
169
- }
170
- }
@@ -1,33 +0,0 @@
1
- import { All, Controller, Inject, Param } from '@midwayjs/core';
2
- import { Context } from '@midwayjs/koa';
3
- import { BaseApiController } from '../base/BaseApiController';
4
- import * as _ from 'lodash';
5
- import { AnyApiService } from '@/service/anyapi/AnyApiService';
6
-
7
- /**
8
- * FaaS方式配置的接口
9
- */
10
- @Controller('/ns/gw/anyApi')
11
- export class AnyApiGatewayController extends BaseApiController {
12
- @Inject()
13
- protected ctx: Context;
14
-
15
- @Inject()
16
- private anyApiService: AnyApiService;
17
-
18
- /**
19
- * 执行配置出来的接口的接口。此接口本身不需要鉴权。鉴权信息在配置中由curdPro底层进行鉴权
20
- */
21
- @All('/execute/:methodCode')
22
- async executeAnyApiMethod(@Param('methodCode') methodCode: string) {
23
- if (!methodCode) {
24
- throw 'method参数不存在';
25
- }
26
-
27
- const headers = _.get(this.ctx, 'request.headers') || {};
28
- const body = _.get(this.ctx, 'request.body') || {};
29
- const query = this.ctx.query || {};
30
-
31
- return await this.anyApiService.executeAnyApiMethod(methodCode, headers, body, query);
32
- }
33
- }
@@ -1,157 +0,0 @@
1
- import * as fs from 'fs';
2
- import * as fs2 from 'node:fs/promises';
3
- import { Controller, Inject, Post, Query, Get } from '@midwayjs/core';
4
- import { Context } from '@midwayjs/koa';
5
- import { BaseApiController } from '../base/BaseApiController';
6
- import { AsyncTaskService } from '@/service/asyncTask/AsyncTaskService';
7
- import { SysAsyncTaskEntity, SysAsyncTaskStatus } from '@/models/AsyncTaskModel';
8
- import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
9
- import { SystemTables } from '@/models/SystemTables';
10
- import { CommonException } from '@/libs/crud-pro/exceptions';
11
- import { checkLogin } from '@/middleware/permission.middleware';
12
- import { parseJsonObject } from '@/libs/utils/functions';
13
-
14
- function fixMyTasksCondition(body: any, ctx: Context) {
15
- if (!body.condition) {
16
- throw new CommonException('参数不正确');
17
- }
18
- body.condition.created_by = ctx.userSession.getSessionInfo().accountId;
19
- }
20
-
21
- function fixCancelBodyData(body: any, id: number) {
22
- if (!body.data || !body.condition) {
23
- throw new CommonException('参数不正确');
24
- }
25
-
26
- // fix condition
27
- const conditionObj: SysAsyncTaskEntity = (body.condition || {}) as any;
28
- conditionObj.id = id;
29
- body.condition = conditionObj;
30
-
31
- // fix data
32
- const dataObj: SysAsyncTaskEntity = (body.data || {}) as any;
33
- dataObj.task_status = SysAsyncTaskStatus.CANCELLED;
34
- body.data = dataObj;
35
- }
36
-
37
- function fixCreateBodyData(body: any, ctx: Context) {
38
- if (!body.data) {
39
- throw new CommonException('参数不正确');
40
- }
41
-
42
- const sessionInfo = ctx.userSession.getSessionInfo();
43
- // fix data
44
- const dataObj: SysAsyncTaskEntity = (body.data || {}) as any;
45
- const input_params = parseJsonObject(dataObj.input_params) || {};
46
- const headers = ctx.headers || {};
47
- input_params.headers = {
48
- fatcmscsrftoken: headers.fatcmscsrftoken,
49
- host: headers.host,
50
- origin: headers.origin,
51
- };
52
- dataObj.task_status = SysAsyncTaskStatus.PENDING;
53
- dataObj.created_by = sessionInfo.accountId;
54
- dataObj.created_user_session = JSON.stringify(sessionInfo); // 创建人的session信息。用于执行时的鉴权。
55
- dataObj.input_params = JSON.stringify(input_params);
56
- }
57
-
58
- /**
59
- * 异步任务框架
60
- */
61
- @Controller('/ns/gw/AsyncTask', { middleware: [checkLogin()] })
62
- export class AsyncTaskController extends BaseApiController {
63
- @Inject()
64
- protected ctx: Context;
65
-
66
- @Inject()
67
- private asyncTaskService: AsyncTaskService;
68
-
69
- // 获取任务列表
70
- @Post('/getMyTasks')
71
- async getMyTasks() {
72
- fixMyTasksCondition(this.ctx.request.body, this.ctx);
73
- return this.executeSysSimpleSQL(SystemTables.sys_async_tasks, KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
74
- }
75
-
76
- // 创建任务
77
- @Post('/createTask')
78
- async createTask() {
79
- //每个用户:5秒内只能创建1次任务
80
- await this.checkUserActionTimeLimit('AsyncTaskController_createTask', 5);
81
-
82
- fixCreateBodyData(this.ctx.request.body, this.ctx);
83
- const res = await this.executeSysSimpleSQL(SystemTables.sys_async_tasks, KeysOfSimpleSQL.SIMPLE_INSERT);
84
- await this.asyncTaskService.startTask();
85
- return res;
86
- }
87
-
88
- // 取消任务
89
- @Post('/cancelTask')
90
- async cancelTask(@Query('id') id: number) {
91
- fixCancelBodyData(this.ctx.request.body, id);
92
- await this.asyncTaskService.cancelTask(id);
93
- await this.executeSysSimpleSQL(SystemTables.sys_async_tasks, KeysOfSimpleSQL.SIMPLE_UPDATE);
94
- return { success: true };
95
- }
96
-
97
- // 下载异步任务的导出文件
98
- @Get('/downloadExportFile')
99
- async downloadExportFile(@Query('task_uuid') task_uuid: string, @Query('id') id: string) {
100
- if (!task_uuid) {
101
- throw new CommonException('task_uuid is not exist');
102
- }
103
- if (!id) {
104
- throw new CommonException('id is not exist');
105
- }
106
-
107
- this.ctx.request.body = {
108
- condition: {
109
- task_uuid: task_uuid,
110
- id: id,
111
- },
112
- };
113
- const res = await this.executeSysSimpleSQL(SystemTables.sys_async_tasks, KeysOfSimpleSQL.SIMPLE_QUERY_ONE);
114
- const taskObj: SysAsyncTaskEntity = res.getOneObj();
115
- if (!taskObj) {
116
- throw new CommonException('任务不存在');
117
- }
118
-
119
- const output_file_path = taskObj.output_file_path;
120
- if (!output_file_path) {
121
- throw new CommonException('导出文件不存在, 可能是任务没有执行完成');
122
- }
123
-
124
- try {
125
- await fs2.access(output_file_path);
126
- } catch (e) {
127
- throw new CommonException('导出文件不存在,可能是文件被删除了。');
128
- }
129
-
130
- await this.responseLocalFileForAsyncTask(taskObj);
131
-
132
- return undefined;
133
- }
134
-
135
- /**
136
- * 响应异步任务的导出文件
137
- * @param taskObj
138
- */
139
- private async responseLocalFileForAsyncTask(taskObj: SysAsyncTaskEntity): Promise<void> {
140
- const output_file_path = taskObj.output_file_path;
141
- const outputFileName = taskObj.task_name + '_' + taskObj.id + '.' + taskObj.output_file_format;
142
-
143
- const stat = await fs2.stat(output_file_path);
144
- const headers = {
145
- 'content-length': '' + stat.size,
146
- 'content-type': 'application/octet-stream',
147
- 'content-disposition': `attachment; filename*=UTF-8''${encodeURIComponent(outputFileName)}`,
148
- };
149
-
150
- const stream = fs.createReadStream(output_file_path);
151
- stream.setMaxListeners(50);
152
- this.logInfo(`[AsyncTaskController]返回本地文件: ${output_file_path}`);
153
- this.ctx.status = 200;
154
- this.ctx.set(headers);
155
- this.ctx.body = stream;
156
- }
157
- }
@@ -1,111 +0,0 @@
1
- import * as _ from 'lodash';
2
- import { decamelizeKeys } from 'humps';
3
- import { Controller, Inject, Param, All } from '@midwayjs/core';
4
- import { Context } from '@midwayjs/koa';
5
- import { CommonResult } from '@/libs/utils/common-dto';
6
- import { WorkbenchService } from '@/service/WorkbenchService';
7
- import { API_BASE_TYPE, ApiBaseService } from '@/service/base/ApiBaseService';
8
- import { CurdProService } from '@/service/curd/CurdProService';
9
- import { CurdMixService } from '@/service/curd/CurdMixService';
10
- import { IRequestCfgModel2 } from '@/models/bizmodels';
11
- import { parseDatabaseName } from '@/libs/crud-pro/utils/DatabaseName';
12
- import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
13
-
14
- const QUERY_AS_LIST = ['condition', 'data'];
15
-
16
- function pickAsQuery(query_as_pick: string, query: any): any {
17
- if (query_as_pick && typeof query_as_pick === 'string') {
18
- const pickArray = query_as_pick.split(',');
19
- return _.pick(query, pickArray);
20
- }
21
- return query;
22
- }
23
-
24
- // /ns/gw/crudApi/getUser?__query_as_condition__=id&_query_as_data__=name&&id=1&name=22
25
- /**
26
- * query形式1:GET: /ns/gw/crudApi/getUser?__query_json__=%7B%22condition%22%3A%7B%22id%22%3A2%7D%7D
27
- * query形式2:GET: /ns/gw/crudApi/getUser?__query_as__=condition&id=1&name=22
28
- * query形式3:GET: /ns/gw/crudApi/createUser?__query_as__=data&__query_pick__=id,name&id=1&name=22
29
- *
30
- * 执行单个配置的接口
31
- */
32
- @Controller('/ns/gw/crudApi')
33
- export class CrudMtdGatewayController extends ApiBaseService {
34
- @Inject()
35
- protected ctx: Context;
36
-
37
- @Inject()
38
- protected workbenchService: WorkbenchService;
39
-
40
- @Inject()
41
- private curdProService: CurdProService;
42
-
43
- @Inject()
44
- private curdMixService: CurdMixService;
45
-
46
- /**
47
- * 执行配置出来的接口的接口。此接口本身不需要鉴权。鉴权信息在配置中由curdPro底层进行鉴权
48
- */
49
- @All('/execute/:methodCode')
50
- async executeCrudMethod(@Param('methodCode') methodCode: string) {
51
- if (!methodCode) {
52
- return CommonResult.errorRes('method参数不存在');
53
- }
54
-
55
- const methodInfo = (await this.curdProService.getCachedCfgByMethod(methodCode)) as any;
56
- if (!methodInfo || methodInfo.status !== 1) {
57
- return CommonResult.errorRes('接口不存在或已下线: ' + methodCode);
58
- }
59
-
60
- this.logInfo('methodInfo=== ', methodInfo);
61
-
62
- const workbench_code_array = methodInfo.workbench_code_array || methodInfo.workbenchCodeArray;
63
- const isSupport = await this.workbenchService.isSupportCurrentWorkbench(workbench_code_array);
64
- if (!isSupport) {
65
- return CommonResult.errorRes('此接口不支持在当前站点打开');
66
- }
67
-
68
- // 权限等校验\服务降级\限流令牌桶
69
- const entity = decamelizeKeys(methodInfo) as any;
70
- await super.beforeCheckApiAccessibility(API_BASE_TYPE.CRUD_METHOD, entity);
71
-
72
- const reqJson: any = {};
73
-
74
- const body = this.ctx.request.body as any;
75
- if (body && typeof body === 'object') {
76
- Object.assign(reqJson, body);
77
- }
78
-
79
- const query = this.ctx.query || {};
80
-
81
- const query_json = query['__query_json__'];
82
- const query_as = query['__query_as__'] as string;
83
- const query_pick = query['__query_pick__'] as string; // 以逗号分割的字段列表。只部分字段作为参数。。
84
-
85
- delete query['__query_json__'];
86
- delete query['__query_as__'];
87
- delete query['__query_pick__'];
88
-
89
- if (query_json && typeof query_json === 'string') {
90
- const queryJson = JSON.parse(query_json);
91
- Object.assign(reqJson, queryJson);
92
- }
93
-
94
- if (query_as && QUERY_AS_LIST.includes(query_as)) {
95
- const pickedQuery = pickAsQuery(query_pick, query);
96
- _.set(reqJson, query_as, pickedQuery);
97
- }
98
-
99
- Object.assign(reqJson, { method: methodCode });
100
-
101
- const cfgModel = methodInfo as IRequestCfgModel2;
102
- const { dbType, dbName } = parseDatabaseName(cfgModel.sqlDatabase);
103
- cfgModel.sqlDatabase = dbName;
104
- cfgModel.sqlDbType = dbType;
105
-
106
- // 业务系统自定义的修改cfgModel
107
- await GLOBAL_STATIC_CONFIG.getConfig().bizUpdateCfgModelForCrudMtd(reqJson, cfgModel, methodInfo, this.ctx);
108
-
109
- return this.curdMixService.executeCrudByCfg(reqJson, cfgModel);
110
- }
111
- }
@@ -1,101 +0,0 @@
1
- import { Controller, Inject, Post } from '@midwayjs/core';
2
- import { Context } from '@midwayjs/koa';
3
- import { BaseApiController } from '../base/BaseApiController';
4
- import { CrudStdService, SPECIAL_SETTING_KEY } from '@/service/crudstd/CrudStdService';
5
- import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
6
- import { IRequestModel } from '@/libs/crud-pro/interfaces';
7
- import { CommonResult } from '@/libs/utils/common-dto';
8
-
9
- interface ICrudStdActionParams {
10
- appCode: string;
11
- settingKey?: string;
12
- }
13
-
14
- type ICrudStdParams = { stdAction: ICrudStdActionParams } & IRequestModel;
15
-
16
- /**
17
- * 零代码配置的界面,相关的接口的执行
18
- */
19
- @Controller('/ns/gw/api/crudStd')
20
- export class CrudStdGatewayController extends BaseApiController {
21
- @Inject()
22
- protected ctx: Context;
23
-
24
- @Inject()
25
- private crudStdService: CrudStdService;
26
-
27
- /**
28
- * 获取零代码应用基本信息
29
- */
30
- @Post('/getParsedCrudStdAppInfo')
31
- async getParsedCrudStdAppInfo(): Promise<CommonResult> {
32
- const body = this.ctx.request.body as ICrudStdParams;
33
- const appCode = body.stdAction.appCode;
34
- const parsedAppInfo = await this.crudStdService.getParsedCrudStdAppInfo(appCode);
35
- return CommonResult.successNotNull(parsedAppInfo);
36
- }
37
-
38
- /**
39
- * 列表查询: 分页查询
40
- */
41
- @Post('/getObjectList')
42
- async getObjectList() {
43
- const { stdAction, ...otherParams } = this.ctx.request.body as ICrudStdParams;
44
- const appCode = stdAction.appCode;
45
- return this.crudStdService.executeStdQuery(appCode, SPECIAL_SETTING_KEY.QUERY_LIST, otherParams, KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
46
- }
47
-
48
- /**
49
- * 单个查询
50
- */
51
- @Post('/getObjectOne')
52
- async getObjectOne() {
53
- const { stdAction, ...otherParams } = this.ctx.request.body as ICrudStdParams;
54
- const appCode = stdAction.appCode;
55
- return this.crudStdService.executeStdQuery(appCode, SPECIAL_SETTING_KEY.QUERY_ONE, otherParams, KeysOfSimpleSQL.SIMPLE_QUERY_ONE);
56
- }
57
-
58
- /**
59
- * 单个删除
60
- */
61
- @Post('/deleteObject')
62
- async deleteObject() {
63
- const { stdAction, ...otherParams } = this.ctx.request.body as ICrudStdParams;
64
- const appCode = stdAction.appCode;
65
- const settingKey = stdAction.settingKey;
66
- return this.crudStdService.executeStdQuery(appCode, settingKey, otherParams, KeysOfSimpleSQL.SIMPLE_DELETE);
67
- }
68
-
69
- /**
70
- * 单个创建
71
- */
72
- @Post('/createObject')
73
- async createObject() {
74
- const { stdAction, ...otherParams } = this.ctx.request.body as ICrudStdParams;
75
- const appCode = stdAction.appCode;
76
- const settingKey = stdAction.settingKey;
77
- return this.crudStdService.executeStdQuery(appCode, settingKey, otherParams, KeysOfSimpleSQL.SIMPLE_INSERT);
78
- }
79
-
80
- /**
81
- * 单个更新
82
- */
83
- @Post('/updateObject')
84
- async updateObject() {
85
- const { stdAction, ...otherParams } = this.ctx.request.body as ICrudStdParams;
86
- const appCode = stdAction.appCode;
87
- const settingKey = stdAction.settingKey;
88
- return this.crudStdService.executeStdQuery(appCode, settingKey, otherParams, KeysOfSimpleSQL.SIMPLE_UPDATE);
89
- }
90
-
91
- /**
92
- * 执行操作
93
- */
94
- @Post('/executeStdAction')
95
- async executeStdAction() {
96
- const { stdAction, ...otherParams } = this.ctx.request.body as ICrudStdParams;
97
- const appCode = stdAction.appCode;
98
- const settingKey = stdAction.settingKey;
99
- return await this.crudStdService.executeStdActionByReq(appCode, settingKey, otherParams);
100
- }
101
- }