midway-fatcms 0.0.1-beta.22 → 0.0.1-beta.24

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 (420) hide show
  1. package/.eslintrc.json +14 -12
  2. package/.prettierrc.js +4 -4
  3. package/README.md +8 -8
  4. package/dist/config/config.default.d.ts +3 -3
  5. package/dist/config/config.default.js +187 -185
  6. package/dist/config/seed/aeskey.txt +1 -1
  7. package/dist/config/utils.d.ts +1 -1
  8. package/dist/config/utils.js +23 -23
  9. package/dist/configuration.d.ts +7 -7
  10. package/dist/configuration.js +113 -114
  11. package/dist/controller/base/BaseApiController.d.ts +37 -31
  12. package/dist/controller/base/BaseApiController.js +164 -146
  13. package/dist/controller/gateway/AnyApiGatewayController.d.ts +13 -13
  14. package/dist/controller/gateway/AnyApiGatewayController.js +55 -55
  15. package/dist/controller/gateway/AsyncTaskController.d.ts +20 -14
  16. package/dist/controller/gateway/AsyncTaskController.js +181 -108
  17. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
  18. package/dist/controller/gateway/CrudMtdGatewayController.js +119 -119
  19. package/dist/controller/gateway/CrudStdGatewayController.d.ts +38 -38
  20. package/dist/controller/gateway/CrudStdGatewayController.js +137 -137
  21. package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
  22. package/dist/controller/gateway/DocGatewayController.js +179 -179
  23. package/dist/controller/gateway/FileController.d.ts +25 -25
  24. package/dist/controller/gateway/FileController.js +129 -129
  25. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
  26. package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
  27. package/dist/controller/gateway/PublicApiController.d.ts +27 -27
  28. package/dist/controller/gateway/PublicApiController.js +165 -165
  29. package/dist/controller/gateway/StaticController.d.ts +24 -23
  30. package/dist/controller/gateway/StaticController.js +288 -284
  31. package/dist/controller/helpers.controller.d.ts +39 -39
  32. package/dist/controller/helpers.controller.js +188 -188
  33. package/dist/controller/home.controller.d.ts +9 -9
  34. package/dist/controller/home.controller.js +71 -71
  35. package/dist/controller/manage/AnyApiMangeApi.d.ts +10 -10
  36. package/dist/controller/manage/AnyApiMangeApi.js +98 -98
  37. package/dist/controller/manage/AppLogMangeApi.d.ts +10 -10
  38. package/dist/controller/manage/AppLogMangeApi.js +88 -88
  39. package/dist/controller/manage/AppMangeApi.d.ts +10 -10
  40. package/dist/controller/manage/AppMangeApi.js +88 -88
  41. package/dist/controller/manage/AppPageMangeApi.d.ts +10 -10
  42. package/dist/controller/manage/AppPageMangeApi.js +87 -87
  43. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +10 -10
  44. package/dist/controller/manage/AppSchemaHistoryApi.js +83 -83
  45. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +10 -10
  46. package/dist/controller/manage/CrudMethodsMangeApi.js +84 -84
  47. package/dist/controller/manage/CrudStandardDesignApi.d.ts +38 -38
  48. package/dist/controller/manage/CrudStandardDesignApi.js +334 -334
  49. package/dist/controller/manage/DataDictManageApi.d.ts +15 -15
  50. package/dist/controller/manage/DataDictManageApi.js +133 -133
  51. package/dist/controller/manage/DeployManageApi.d.ts +19 -19
  52. package/dist/controller/manage/DeployManageApi.js +180 -180
  53. package/dist/controller/manage/DocLibManageApi.d.ts +10 -10
  54. package/dist/controller/manage/DocLibManageApi.js +104 -104
  55. package/dist/controller/manage/DocManageApi.d.ts +11 -11
  56. package/dist/controller/manage/DocManageApi.js +130 -130
  57. package/dist/controller/manage/FileManageApi.d.ts +13 -13
  58. package/dist/controller/manage/FileManageApi.js +77 -77
  59. package/dist/controller/manage/LowCodeTplManageApi.d.ts +13 -13
  60. package/dist/controller/manage/LowCodeTplManageApi.js +86 -86
  61. package/dist/controller/manage/MenuManageApi.d.ts +10 -10
  62. package/dist/controller/manage/MenuManageApi.js +93 -93
  63. package/dist/controller/manage/ProxyApiMangeApi.d.ts +10 -10
  64. package/dist/controller/manage/ProxyApiMangeApi.js +87 -87
  65. package/dist/controller/manage/SuperAdminManageApi.d.ts +24 -24
  66. package/dist/controller/manage/SuperAdminManageApi.js +153 -153
  67. package/dist/controller/manage/SysConfigMangeApi.d.ts +11 -11
  68. package/dist/controller/manage/SysConfigMangeApi.js +126 -126
  69. package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
  70. package/dist/controller/manage/SystemInfoManageApi.js +72 -72
  71. package/dist/controller/manage/UserAccountManageApi.d.ts +14 -14
  72. package/dist/controller/manage/UserAccountManageApi.js +129 -129
  73. package/dist/controller/manage/WorkbenchMangeApi.d.ts +11 -11
  74. package/dist/controller/manage/WorkbenchMangeApi.js +103 -103
  75. package/dist/controller/myinfo/AuthController.d.ts +33 -33
  76. package/dist/controller/myinfo/AuthController.js +136 -136
  77. package/dist/controller/myinfo/MyInfoController.d.ts +13 -13
  78. package/dist/controller/myinfo/MyInfoController.js +51 -51
  79. package/dist/controller/render/AppRenderController.d.ts +11 -11
  80. package/dist/controller/render/AppRenderController.js +91 -91
  81. package/dist/controller/test.controller.d.ts +8 -8
  82. package/dist/controller/test.controller.js +51 -51
  83. package/dist/filter/default.filter.d.ts +7 -7
  84. package/dist/filter/default.filter.js +23 -23
  85. package/dist/filter/notfound.filter.d.ts +5 -5
  86. package/dist/filter/notfound.filter.js +20 -20
  87. package/dist/index.d.ts +102 -101
  88. package/dist/index.js +120 -119
  89. package/dist/interface.d.ts +27 -27
  90. package/dist/interface.js +3 -3
  91. package/dist/libs/crud-pro/CrudPro.d.ts +37 -37
  92. package/dist/libs/crud-pro/CrudPro.js +136 -136
  93. package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
  94. package/dist/libs/crud-pro/defaultConfigs.js +15 -15
  95. package/dist/libs/crud-pro/exceptions.d.ts +104 -104
  96. package/dist/libs/crud-pro/exceptions.js +117 -117
  97. package/dist/libs/crud-pro/interfaces.d.ts +163 -163
  98. package/dist/libs/crud-pro/interfaces.js +12 -12
  99. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -43
  100. package/dist/libs/crud-pro/models/ExecuteContext.js +79 -79
  101. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -38
  102. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -72
  103. package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
  104. package/dist/libs/crud-pro/models/FuncContext.js +6 -6
  105. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
  106. package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
  107. package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
  108. package/dist/libs/crud-pro/models/RequestModel.js +113 -113
  109. package/dist/libs/crud-pro/models/ResModel.d.ts +16 -16
  110. package/dist/libs/crud-pro/models/ResModel.js +2 -2
  111. package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
  112. package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
  113. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +22 -22
  114. package/dist/libs/crud-pro/models/SqlCfgModel.js +40 -40
  115. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +6 -6
  116. package/dist/libs/crud-pro/models/SqlSegArg.js +12 -12
  117. package/dist/libs/crud-pro/models/Transaction.d.ts +29 -29
  118. package/dist/libs/crud-pro/models/Transaction.js +67 -67
  119. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +28 -28
  120. package/dist/libs/crud-pro/models/TransactionMySQL.js +76 -76
  121. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +28 -28
  122. package/dist/libs/crud-pro/models/TransactionPostgres.js +85 -85
  123. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +34 -34
  124. package/dist/libs/crud-pro/models/TransactionSqlServer.js +92 -92
  125. package/dist/libs/crud-pro/models/keys.d.ts +106 -106
  126. package/dist/libs/crud-pro/models/keys.js +149 -149
  127. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -11
  128. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -73
  129. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
  130. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +112 -112
  131. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
  132. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -223
  133. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +9 -9
  134. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +51 -51
  135. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +13 -13
  136. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +148 -148
  137. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +24 -24
  138. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +340 -340
  139. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
  140. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -165
  141. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
  142. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +334 -334
  143. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -24
  144. package/dist/libs/crud-pro/services/CrudProServiceBase.js +79 -79
  145. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -9
  146. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +78 -78
  147. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +32 -32
  148. package/dist/libs/crud-pro/services/CurdProServiceHub.js +64 -64
  149. package/dist/libs/crud-pro/sql.txt +120 -120
  150. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +9 -9
  151. package/dist/libs/crud-pro/utils/CompareUtils.js +25 -25
  152. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +9 -9
  153. package/dist/libs/crud-pro/utils/DatabaseName.js +50 -50
  154. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +7 -7
  155. package/dist/libs/crud-pro/utils/DateTimeUtils.js +21 -21
  156. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +19 -19
  157. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +47 -47
  158. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +5 -5
  159. package/dist/libs/crud-pro/utils/MessageParseUtils.js +33 -33
  160. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +39 -39
  161. package/dist/libs/crud-pro/utils/MixinUtils.js +255 -255
  162. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +11 -11
  163. package/dist/libs/crud-pro/utils/ModelUtils.js +49 -49
  164. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +11 -11
  165. package/dist/libs/crud-pro/utils/MultiKeyMap.js +63 -63
  166. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +5 -5
  167. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +29 -29
  168. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +40 -40
  169. package/dist/libs/crud-pro/utils/TypeUtils.js +166 -166
  170. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +3 -3
  171. package/dist/libs/crud-pro/utils/ValidateUtils.js +165 -165
  172. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +3 -3
  173. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +19 -19
  174. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +3 -3
  175. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +20 -20
  176. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +3 -3
  177. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +20 -20
  178. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +4 -4
  179. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +21 -21
  180. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -3
  181. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -22
  182. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +2 -2
  183. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +11 -11
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +11 -11
  186. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +2 -2
  187. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +128 -128
  188. package/dist/libs/global-config/global-config.d.ts +45 -45
  189. package/dist/libs/global-config/global-config.js +33 -33
  190. package/dist/libs/utils/common-dto.d.ts +18 -18
  191. package/dist/libs/utils/common-dto.js +40 -40
  192. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  193. package/dist/libs/utils/crypto-utils.js +46 -46
  194. package/dist/libs/utils/errorToString.d.ts +2 -2
  195. package/dist/libs/utils/errorToString.js +57 -57
  196. package/dist/libs/utils/fatcms-request.d.ts +30 -30
  197. package/dist/libs/utils/fatcms-request.js +104 -104
  198. package/dist/libs/utils/functions.d.ts +5 -4
  199. package/dist/libs/utils/functions.js +68 -63
  200. package/dist/libs/utils/ordernum-utils.d.ts +2 -2
  201. package/dist/libs/utils/ordernum-utils.js +13 -13
  202. package/dist/libs/utils/parseConfig.d.ts +7 -7
  203. package/dist/libs/utils/parseConfig.js +44 -44
  204. package/dist/libs/utils/parseCreateSql.d.ts +5 -5
  205. package/dist/libs/utils/parseCreateSql.js +86 -86
  206. package/dist/libs/utils/render-utils.d.ts +28 -28
  207. package/dist/libs/utils/render-utils.js +135 -135
  208. package/dist/middleware/forbidden.middleware.d.ts +10 -10
  209. package/dist/middleware/forbidden.middleware.js +54 -54
  210. package/dist/middleware/global.middleware.d.ts +10 -10
  211. package/dist/middleware/global.middleware.js +253 -253
  212. package/dist/middleware/permission.middleware.d.ts +18 -18
  213. package/dist/middleware/permission.middleware.js +74 -74
  214. package/dist/middleware/tx.middleware.d.ts +9 -9
  215. package/dist/middleware/tx.middleware.js +40 -40
  216. package/dist/models/AsyncTaskModel.d.ts +72 -69
  217. package/dist/models/AsyncTaskModel.js +29 -26
  218. package/dist/models/RedisKeys.d.ts +11 -8
  219. package/dist/models/RedisKeys.js +14 -11
  220. package/dist/models/SystemEntities.d.ts +98 -98
  221. package/dist/models/SystemEntities.js +2 -2
  222. package/dist/models/SystemPerm.d.ts +95 -95
  223. package/dist/models/SystemPerm.js +100 -100
  224. package/dist/models/SystemTables.d.ts +25 -25
  225. package/dist/models/SystemTables.js +28 -28
  226. package/dist/models/bizmodels.d.ts +96 -69
  227. package/dist/models/bizmodels.js +39 -34
  228. package/dist/models/contextLogger.d.ts +25 -25
  229. package/dist/models/contextLogger.js +112 -112
  230. package/dist/models/devops.d.ts +12 -12
  231. package/dist/models/devops.js +19 -19
  232. package/dist/models/userSession.d.ts +61 -61
  233. package/dist/models/userSession.js +165 -165
  234. package/dist/schedule/anonymousContext.d.ts +14 -13
  235. package/dist/schedule/anonymousContext.js +59 -59
  236. package/dist/schedule/index.d.ts +4 -4
  237. package/dist/schedule/index.js +10 -10
  238. package/dist/schedule/runSchedule.d.ts +12 -15
  239. package/dist/schedule/runSchedule.js +68 -68
  240. package/dist/schedule/scheduleNames.d.ts +13 -13
  241. package/dist/schedule/scheduleNames.js +17 -17
  242. package/dist/service/AuthService.d.ts +70 -70
  243. package/dist/service/AuthService.js +251 -251
  244. package/dist/service/EnumInfoService.d.ts +30 -30
  245. package/dist/service/EnumInfoService.js +126 -126
  246. package/dist/service/FileCenterService.d.ts +43 -43
  247. package/dist/service/FileCenterService.js +351 -351
  248. package/dist/service/SysConfigService.d.ts +7 -7
  249. package/dist/service/SysConfigService.js +47 -47
  250. package/dist/service/UserAccountService.d.ts +23 -23
  251. package/dist/service/UserAccountService.js +107 -107
  252. package/dist/service/UserSessionService.d.ts +16 -16
  253. package/dist/service/UserSessionService.js +86 -86
  254. package/dist/service/VisitStatService.d.ts +14 -14
  255. package/dist/service/VisitStatService.js +158 -158
  256. package/dist/service/WorkbenchService.d.ts +20 -20
  257. package/dist/service/WorkbenchService.js +159 -155
  258. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  259. package/dist/service/anyapi/AnyApiSandboxService.js +122 -122
  260. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  261. package/dist/service/anyapi/AnyApiService.js +181 -181
  262. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +37 -37
  263. package/dist/service/asyncTask/AsyncTaskRunnerService.js +242 -232
  264. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -7
  265. package/dist/service/asyncTask/AsyncTaskService.js +34 -34
  266. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
  267. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
  268. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
  269. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +197 -0
  270. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
  271. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +130 -0
  272. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
  273. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +121 -0
  274. package/dist/service/base/ApiBaseService.d.ts +15 -15
  275. package/dist/service/base/ApiBaseService.js +50 -50
  276. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  277. package/dist/service/base/ApiRateLimiter.js +51 -51
  278. package/dist/service/base/BaseService.d.ts +41 -29
  279. package/dist/service/base/BaseService.js +101 -79
  280. package/dist/service/base/RedisCacheService.d.ts +13 -13
  281. package/dist/service/base/RedisCacheService.js +50 -50
  282. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  283. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  284. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  285. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  286. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  287. package/dist/service/crudstd/CrudStdRelationService.js +85 -85
  288. package/dist/service/crudstd/CrudStdService.d.ts +63 -51
  289. package/dist/service/crudstd/CrudStdService.js +259 -227
  290. package/dist/service/curd/CrudProQuick.d.ts +24 -24
  291. package/dist/service/curd/CrudProQuick.js +109 -105
  292. package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
  293. package/dist/service/curd/CurdMixByAccountService.js +93 -93
  294. package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
  295. package/dist/service/curd/CurdMixByDictService.js +114 -113
  296. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -31
  297. package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -202
  298. package/dist/service/curd/CurdMixBySysConfigService.d.ts +9 -9
  299. package/dist/service/curd/CurdMixBySysConfigService.js +80 -80
  300. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +10 -10
  301. package/dist/service/curd/CurdMixByWorkbenchService.js +78 -78
  302. package/dist/service/curd/CurdMixService.d.ts +27 -17
  303. package/dist/service/curd/CurdMixService.js +100 -76
  304. package/dist/service/curd/CurdMixUtils.d.ts +51 -35
  305. package/dist/service/curd/CurdMixUtils.js +275 -238
  306. package/dist/service/curd/CurdProService.d.ts +32 -31
  307. package/dist/service/curd/CurdProService.js +210 -207
  308. package/dist/service/curd/fixCfgModel.d.ts +3 -3
  309. package/dist/service/curd/fixCfgModel.js +107 -107
  310. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  311. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  312. package/dist/service/proxyapi/ProxyApiService.d.ts +60 -60
  313. package/dist/service/proxyapi/ProxyApiService.js +260 -260
  314. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  315. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  316. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  317. package/dist/service/proxyapi/RouteHandler.js +9 -9
  318. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  319. package/dist/service/proxyapi/RouteTrie.js +63 -63
  320. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  321. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  322. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  323. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  324. package/dist/views/404_app.html +31 -31
  325. package/dist/views/404_workbench.html +34 -34
  326. package/index.d.ts +10 -10
  327. package/package.json +80 -78
  328. package/src/config/config.default.ts +207 -203
  329. package/src/config/seed/aeskey.txt +1 -1
  330. package/src/config/utils.ts +2 -3
  331. package/src/configuration.ts +5 -12
  332. package/src/controller/base/BaseApiController.ts +21 -3
  333. package/src/controller/gateway/AsyncTaskController.ts +76 -2
  334. package/src/controller/gateway/StaticController.ts +15 -12
  335. package/src/controller/manage/AnyApiMangeApi.ts +66 -66
  336. package/src/controller/manage/AppLogMangeApi.ts +53 -53
  337. package/src/controller/manage/AppMangeApi.ts +53 -53
  338. package/src/controller/manage/AppPageMangeApi.ts +52 -52
  339. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -49
  340. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -49
  341. package/src/controller/manage/DataDictManageApi.ts +78 -78
  342. package/src/controller/manage/DocLibManageApi.ts +69 -69
  343. package/src/controller/manage/DocManageApi.ts +99 -99
  344. package/src/controller/manage/FileManageApi.ts +45 -45
  345. package/src/controller/manage/LowCodeTplManageApi.ts +52 -52
  346. package/src/controller/manage/MenuManageApi.ts +58 -58
  347. package/src/controller/manage/ProxyApiMangeApi.ts +52 -52
  348. package/src/controller/manage/SysConfigMangeApi.ts +95 -95
  349. package/src/controller/manage/UserAccountManageApi.ts +94 -94
  350. package/src/controller/manage/WorkbenchMangeApi.ts +72 -72
  351. package/src/index.ts +106 -105
  352. package/src/interface.ts +31 -31
  353. package/src/libs/crud-pro/models/ExecuteContext.ts +13 -4
  354. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +2 -3
  355. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +8 -9
  356. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -86
  357. package/src/libs/crud-pro/sql.txt +120 -120
  358. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +26 -26
  359. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +25 -25
  360. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +11 -11
  361. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +11 -11
  362. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +129 -129
  363. package/src/libs/utils/functions.ts +73 -67
  364. package/src/libs/utils/render-utils.ts +184 -184
  365. package/src/middleware/permission.middleware.ts +1 -2
  366. package/src/models/AsyncTaskModel.ts +82 -79
  367. package/src/models/RedisKeys.ts +10 -11
  368. package/src/models/SystemEntities.ts +115 -115
  369. package/src/models/SystemPerm.ts +105 -105
  370. package/src/models/SystemTables.ts +27 -27
  371. package/src/models/bizmodels.ts +120 -88
  372. package/src/models/contextLogger.ts +132 -132
  373. package/src/models/devops.ts +17 -17
  374. package/src/models/userSession.ts +216 -216
  375. package/src/schedule/anonymousContext.ts +17 -23
  376. package/src/schedule/index.ts +12 -12
  377. package/src/schedule/runSchedule.ts +82 -83
  378. package/src/schedule/scheduleNames.ts +21 -21
  379. package/src/service/AuthService.ts +275 -275
  380. package/src/service/EnumInfoService.ts +22 -27
  381. package/src/service/FileCenterService.ts +0 -5
  382. package/src/service/SysConfigService.ts +4 -5
  383. package/src/service/UserAccountService.ts +107 -110
  384. package/src/service/UserSessionService.ts +12 -16
  385. package/src/service/WorkbenchService.ts +15 -15
  386. package/src/service/anyapi/AnyApiSandboxService.ts +121 -121
  387. package/src/service/anyapi/AnyApiService.ts +187 -187
  388. package/src/service/asyncTask/AsyncTaskRunnerService.ts +19 -8
  389. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  390. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +224 -0
  391. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +147 -0
  392. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +138 -0
  393. package/src/service/base/ApiBaseService.ts +3 -3
  394. package/src/service/base/ApiRateLimiter.ts +59 -59
  395. package/src/service/base/BaseService.ts +100 -74
  396. package/src/service/base/RedisCacheService.ts +38 -38
  397. package/src/service/crudstd/CrudStdActionService.ts +27 -27
  398. package/src/service/crudstd/CrudStdConstant.ts +62 -62
  399. package/src/service/crudstd/CrudStdRelationService.ts +78 -78
  400. package/src/service/crudstd/CrudStdService.ts +283 -243
  401. package/src/service/curd/CrudProQuick.ts +11 -17
  402. package/src/service/curd/CurdMixByAccountService.ts +8 -9
  403. package/src/service/curd/CurdMixByDictService.ts +19 -24
  404. package/src/service/curd/CurdMixByLinkToCustomService.ts +10 -9
  405. package/src/service/curd/CurdMixBySysConfigService.ts +8 -13
  406. package/src/service/curd/CurdMixByWorkbenchService.ts +7 -8
  407. package/src/service/curd/CurdMixService.ts +37 -5
  408. package/src/service/curd/CurdMixUtils.ts +65 -45
  409. package/src/service/curd/CurdProService.ts +42 -48
  410. package/src/service/curd/fixCfgModel.ts +139 -139
  411. package/src/service/proxyapi/ProxyApiLoadService.ts +174 -174
  412. package/src/service/proxyapi/ProxyApiService.ts +262 -262
  413. package/src/service/proxyapi/ProxyApiUtils.ts +32 -32
  414. package/src/service/proxyapi/RouteHandler.ts +8 -8
  415. package/src/service/proxyapi/RouteTrie.ts +74 -74
  416. package/src/service/proxyapi/WeightedRandom.ts +37 -37
  417. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -44
  418. package/src/views/404_app.html +31 -31
  419. package/src/views/404_workbench.html +34 -34
  420. package/tsconfig.json +32 -32
@@ -1,203 +1,207 @@
1
- import { MidwayConfig } from '@midwayjs/core';
2
- import { tmpdir } from 'os';
3
- import { join } from 'path';
4
- import { readFileSync } from 'fs';
5
-
6
- export default (appInfo: any) => {
7
- return {
8
- siteFile: {
9
- favicon: readFileSync(join(__dirname, '../views/static/favicon.ico')),
10
- },
11
-
12
- encryptedFieldList: [],
13
-
14
- /**
15
- * 内置超级管理员用户
16
- * 可以使用这个工具生成:http://127.0.0.1:7002/ns/api/helpers/generateDatabasePassword?loginName=xxxx&pw0=xxxx
17
- */
18
- superAdminList: [
19
- {
20
- pwd_salt: 'c837f8c6de7261de228ec58b1b3ca9fa1htbvgm88',
21
- pwd_md5: 'e334410fca1fd49972f63bf91f3be1be',
22
- login_name: 'superadmin',
23
- },
24
- ],
25
-
26
- // use for cookie sign key, should change to your own and keep security
27
- keys: '1715169944707_323',
28
-
29
- koa: {
30
- port: 7002,
31
- },
32
-
33
- cors: {
34
- allowMethods: 'GET,HEAD,PUT,POST,DELETE,PATCH',
35
- origin: '*',
36
- },
37
-
38
- bodyParser: {
39
- enableTypes: ['json', 'form', 'text', 'xml'],
40
- formLimit: '1mb',
41
- jsonLimit: '1mb',
42
- textLimit: '1mb',
43
- xmlLimit: '1mb',
44
- ignore: [
45
- '/ns/gw/proxy/*',
46
- '/ns/gw/file/uploadFile',
47
- '/ns/api/manage/deploy/uploadAssets',
48
- ], // 忽略代理路径的 body 解析
49
- },
50
-
51
- mysql2: {
52
- fatcms: {
53
- host: '127.0.0.1',
54
- port: '3306',
55
- database: 'fatcms',
56
- user: 'root',
57
- password: '123456',
58
- charset: 'utf8',
59
- connectTimeout: 30000,
60
- connectionLimit: 10,
61
- multipleStatements: true,
62
- },
63
- },
64
- postgres2: {
65
- postgres_test_fatcms_inner_demo_config: {
66
- user: 'postgres',
67
- host: '127.0.0.1',
68
- database: 'postgres',
69
- password: '123456',
70
- port: 5432, // 默认 PostgreSQL 端口
71
- max: 20, // 连接池最大连接数
72
- idleTimeoutMillis: 30000, // 空闲连接超时时间(毫秒)
73
- connectionTimeoutMillis: 2000, // 连接超时时间(毫秒)
74
- },
75
- },
76
-
77
- sqlserver2: {
78
- sqlserver_master_fatcms_inner_demo_config: {
79
- user: 'sa',
80
- password: '123456', // 你的SA密码
81
- server: '127.0.0.1',
82
- port: 1433,
83
- database: 'master', // 默认数据库
84
- options: {
85
- encrypt: false, // Docker容器内通常不需要加密
86
- trustServerCertificate: true, // 信任自签名证书
87
- },
88
- pool: {
89
- max: 30, // 最大连接数
90
- min: 1, // 最小连接数
91
- idleTimeoutMillis: 30000, // 连接空闲超时时间(毫秒)
92
- },
93
- },
94
- },
95
-
96
- redis: {
97
- client: {
98
- port: 6379, // Redis port
99
- host: '127.0.0.1', // Redis host
100
- },
101
- },
102
-
103
- oss: {
104
- clients: {
105
- privateBucket: {
106
- accessKeyId: '123',
107
- accessKeySecret: '123',
108
- bucket: 'bucket_name1',
109
- endpoint: 'oss-cn-shanghai.aliyuncs.com',
110
- timeout: '60s',
111
- },
112
- publicBucket: {
113
- accessKeyId: '123',
114
- accessKeySecret: '123',
115
- bucket: 'bucket_name2',
116
- endpoint: 'oss-cn-shanghai.aliyuncs.com',
117
- timeout: '60s',
118
- },
119
- },
120
- },
121
-
122
- upload: {
123
- // mode: UploadMode, 默认为file,即上传到服务器临时目录,可以配置为 stream
124
- mode: 'file',
125
- // fileSize: string, 最大上传文件大小,默认为 10mb
126
- fileSize: '20mb',
127
- limit: '20mb',
128
- // whitelist: string[],文件扩展名白名单
129
- whitelist: [
130
- '.jpg',
131
- '.jpeg',
132
- '.png',
133
- '.gif',
134
- '.pdf',
135
- '.zip',
136
- '.xlsx',
137
- '.docx',
138
- '.pptx',
139
- '.txt',
140
- '.md',
141
- '.json',
142
- '.js',
143
- '.cjs',
144
- '.ejs',
145
- '.jsx',
146
- '.css',
147
- '.java',
148
- '.ts',
149
- '.tsx',
150
- '.less',
151
- '.scss',
152
- '.html',
153
- '.ttf',
154
- '.map',
155
- '.svg',
156
- ],
157
- // tmpdir: string,上传的文件临时存储路径
158
- tmpdir: join(tmpdir(), 'fatcms-upload-files'),
159
- // cleanTimeout: number,上传的文件在临时目录中多久之后自动删除,默认为 5 分钟
160
- cleanTimeout: 5 * 60 * 1000,
161
- // base64: boolean,设置原始body是否是base64格式,默认为false,一般用于腾讯云的兼容
162
- base64: false,
163
- // 仅在匹配路径到 /api/upload 的时候去解析 body 中的文件信息
164
- match: ['/ns/gw/file/uploadFile', '/ns/api/manage/deploy/uploadAssets'],
165
- },
166
-
167
- view: {
168
- rootDir: {
169
- default: join(__dirname, '../views'),
170
- },
171
- defaultExtension: '.html',
172
- defaultViewEngine: 'ejs',
173
- mapping: {
174
- '.ejs': 'ejs',
175
- '.html': 'ejs',
176
- },
177
- },
178
- // ejs config
179
- ejs: {},
180
-
181
- info: {
182
- infoPath: `/_my_info_${Date.now()}_${Math.floor(
183
- Math.random() * 1000000
184
- )}`, // 实际上隐藏了info路径
185
- },
186
-
187
- // 使用浏览器插件配置header信息:插件名:ModHeader - Modify HTTP headers
188
- // 默认值:配置key:fatcmsdebug, 配置value: headerSecret的值
189
- fatcmsDebug: {
190
- headerKey: 'fatcmsDebug',
191
- headerSecret: '111',
192
- },
193
-
194
- // 是否开启SA账号。只有账号密码没有用,必须通过ModHeader插件设置如下字段
195
- fatcmsSAEnable: {
196
- headerKey: 'fatcmsSAEnable',
197
- headerSecret: '222',
198
- },
199
-
200
- // 是否启用内置的定时任务
201
- fatcmsScheduleService: true,
202
- } as MidwayConfig;
203
- };
1
+ import { MidwayConfig } from '@midwayjs/core';
2
+ import { tmpdir } from 'os';
3
+ import { join } from 'path';
4
+ import { readFileSync } from 'fs';
5
+
6
+ export default (appInfo: any) => {
7
+ return {
8
+ siteFile: {
9
+ favicon: readFileSync(join(__dirname, '../views/static/favicon.ico')),
10
+ },
11
+
12
+ encryptedFieldList: [],
13
+
14
+ /**
15
+ * 内置超级管理员用户
16
+ * 可以使用这个工具生成:http://127.0.0.1:7002/ns/api/helpers/generateDatabasePassword?loginName=xxxx&pw0=xxxx
17
+ */
18
+ superAdminList: [
19
+ {
20
+ pwd_salt: 'c837f8c6de7261de228ec58b1b3ca9fa1htbvgm88',
21
+ pwd_md5: 'e334410fca1fd49972f63bf91f3be1be',
22
+ login_name: 'superadmin',
23
+ },
24
+ ],
25
+
26
+ // use for cookie sign key, should change to your own and keep security
27
+ keys: '1715169944707_323',
28
+
29
+ koa: {
30
+ port: 7002,
31
+ },
32
+
33
+ cors: {
34
+ allowMethods: 'GET,HEAD,PUT,POST,DELETE,PATCH',
35
+ origin: '*',
36
+ },
37
+
38
+ bodyParser: {
39
+ enableTypes: ['json', 'form', 'text', 'xml'],
40
+ formLimit: '1mb',
41
+ jsonLimit: '1mb',
42
+ textLimit: '1mb',
43
+ xmlLimit: '1mb',
44
+ ignore: [
45
+ '/ns/gw/proxy/*',
46
+ '/ns/gw/file/uploadFile',
47
+ '/ns/api/manage/deploy/uploadAssets',
48
+ ], // 忽略代理路径的 body 解析
49
+ },
50
+
51
+ mysql2: {
52
+ fatcms: {
53
+ host: '127.0.0.1',
54
+ port: '3306',
55
+ database: 'fatcms',
56
+ user: 'root',
57
+ password: '123456',
58
+ charset: 'utf8',
59
+ connectTimeout: 30000,
60
+ connectionLimit: 10,
61
+ multipleStatements: true,
62
+ },
63
+ },
64
+ postgres2: {
65
+ postgres_test_fatcms_inner_demo_config: {
66
+ user: 'postgres',
67
+ host: '127.0.0.1',
68
+ database: 'postgres',
69
+ password: '123456',
70
+ port: 5432, // 默认 PostgreSQL 端口
71
+ max: 20, // 连接池最大连接数
72
+ idleTimeoutMillis: 30000, // 空闲连接超时时间(毫秒)
73
+ connectionTimeoutMillis: 2000, // 连接超时时间(毫秒)
74
+ },
75
+ },
76
+
77
+ sqlserver2: {
78
+ sqlserver_master_fatcms_inner_demo_config: {
79
+ user: 'sa',
80
+ password: '123456', // 你的SA密码
81
+ server: '127.0.0.1',
82
+ port: 1433,
83
+ database: 'master', // 默认数据库
84
+ options: {
85
+ encrypt: false, // Docker容器内通常不需要加密
86
+ trustServerCertificate: true, // 信任自签名证书
87
+ },
88
+ pool: {
89
+ max: 30, // 最大连接数
90
+ min: 1, // 最小连接数
91
+ idleTimeoutMillis: 30000, // 连接空闲超时时间(毫秒)
92
+ },
93
+ },
94
+ },
95
+
96
+ redis: {
97
+ client: {
98
+ port: 6379, // Redis port
99
+ host: '127.0.0.1', // Redis host
100
+ },
101
+ },
102
+
103
+ oss: {
104
+ clients: {
105
+ privateBucket: {
106
+ accessKeyId: '123',
107
+ accessKeySecret: '123',
108
+ bucket: 'bucket_name1',
109
+ endpoint: 'oss-cn-shanghai.aliyuncs.com',
110
+ timeout: '60s',
111
+ },
112
+ publicBucket: {
113
+ accessKeyId: '123',
114
+ accessKeySecret: '123',
115
+ bucket: 'bucket_name2',
116
+ endpoint: 'oss-cn-shanghai.aliyuncs.com',
117
+ timeout: '60s',
118
+ },
119
+ },
120
+ },
121
+
122
+ upload: {
123
+ // mode: UploadMode, 默认为file,即上传到服务器临时目录,可以配置为 stream
124
+ mode: 'file',
125
+ // fileSize: string, 最大上传文件大小,默认为 10mb
126
+ fileSize: '20mb',
127
+ limit: '20mb',
128
+ // whitelist: string[],文件扩展名白名单
129
+ whitelist: [
130
+ '.jpg',
131
+ '.jpeg',
132
+ '.png',
133
+ '.gif',
134
+ '.pdf',
135
+ '.zip',
136
+ '.xlsx',
137
+ '.docx',
138
+ '.pptx',
139
+ '.txt',
140
+ '.md',
141
+ '.json',
142
+ '.js',
143
+ '.cjs',
144
+ '.ejs',
145
+ '.jsx',
146
+ '.css',
147
+ '.java',
148
+ '.ts',
149
+ '.tsx',
150
+ '.less',
151
+ '.scss',
152
+ '.html',
153
+ '.ttf',
154
+ '.map',
155
+ '.svg',
156
+ ],
157
+ // tmpdir: string,上传的文件临时存储路径
158
+ tmpdir: join(tmpdir(), 'fatcms-upload-files'),
159
+ // cleanTimeout: number,上传的文件在临时目录中多久之后自动删除,默认为 5 分钟
160
+ cleanTimeout: 5 * 60 * 1000,
161
+ // base64: boolean,设置原始body是否是base64格式,默认为false,一般用于腾讯云的兼容
162
+ base64: false,
163
+ // 仅在匹配路径到 /api/upload 的时候去解析 body 中的文件信息
164
+ match: ['/ns/gw/file/uploadFile', '/ns/api/manage/deploy/uploadAssets'],
165
+ },
166
+
167
+ view: {
168
+ rootDir: {
169
+ default: join(__dirname, '../views'),
170
+ },
171
+ defaultExtension: '.html',
172
+ defaultViewEngine: 'ejs',
173
+ mapping: {
174
+ '.ejs': 'ejs',
175
+ '.html': 'ejs',
176
+ },
177
+ },
178
+ // ejs config
179
+ ejs: {},
180
+
181
+ info: {
182
+ infoPath: `/_my_info_${Date.now()}_${Math.floor(
183
+ Math.random() * 1000000
184
+ )}`, // 实际上隐藏了info路径
185
+ },
186
+
187
+ // 使用浏览器插件配置header信息:插件名:ModHeader - Modify HTTP headers
188
+ // 默认值:配置key:fatcmsdebug, 配置value: headerSecret的值
189
+ fatcmsDebug: {
190
+ headerKey: 'fatcmsDebug',
191
+ headerSecret: '111',
192
+ },
193
+
194
+ // 是否开启SA账号。只有账号密码没有用,必须通过ModHeader插件设置如下字段
195
+ fatcmsSAEnable: {
196
+ headerKey: 'fatcmsSAEnable',
197
+ headerSecret: '222',
198
+ },
199
+
200
+ // 是否启用内置的定时任务
201
+ fatcmsScheduleService: true,
202
+
203
+ // Excel导出文件的临时目录
204
+ fatcmsExportExcelTmpFilePath: join(tmpdir(), 'fatcms-export-excel'),
205
+
206
+ } as MidwayConfig;
207
+ };
@@ -1 +1 @@
1
- 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
@@ -1,9 +1,8 @@
1
1
  import { readFileSync, existsSync } from 'fs';
2
- import * as path from 'path'
2
+ import * as path from 'path';
3
3
 
4
4
  export function readJsonFileSync(filePath0: string) {
5
-
6
- const filePath = path.join(__dirname, filePath0)
5
+ const filePath = path.join(__dirname, filePath0);
7
6
 
8
7
  try {
9
8
  // 检查文件是否存在
@@ -13,7 +13,7 @@ import { join } from 'path';
13
13
  // import { NotFoundFilter } from './filter/notfound.filter';
14
14
  import { GlobalMiddleware } from './middleware/global.middleware';
15
15
  import { ForbiddenMiddleware } from './middleware/forbidden.middleware';
16
- import { SCHEDULE_QUEUE , ANONYMOUS_CONTEXT, INNER_SCHEDULE_INTERVAL } from './schedule';
16
+ import { SCHEDULE_QUEUE, ANONYMOUS_CONTEXT, INNER_SCHEDULE_INTERVAL } from './schedule';
17
17
  import { privateAES } from './libs/utils/crypto-utils';
18
18
 
19
19
  @Configuration({
@@ -45,16 +45,13 @@ export class ContainerLifeCycle {
45
45
  for (let i = 0; i < encryptedFieldList.length; i++) {
46
46
  const field = encryptedFieldList[i];
47
47
  try {
48
-
49
48
  const encryptedValue = _.get(config, field);
50
49
 
51
50
  if (encryptedValue && typeof encryptedValue === 'string') {
52
51
  const newInput = await privateAES.time_decrypt_base64_utf8(encryptedValue);
53
52
  _.set(newConfig, field, newInput);
54
53
  }
55
-
56
54
  } catch (e) {
57
- console.error('ContainerLifeCycle ==> 解密配置字段失败: ' + field);
58
55
  logger.error('ContainerLifeCycle ==> onConfigLoad 解密配置字段失败: ' + field);
59
56
  }
60
57
  }
@@ -63,7 +60,6 @@ export class ContainerLifeCycle {
63
60
  }
64
61
 
65
62
  async onReady() {
66
-
67
63
  /**
68
64
  * 让ANONYMOUS_CONTEXT获取app对象
69
65
  */
@@ -93,16 +89,16 @@ export class ContainerLifeCycle {
93
89
  }
94
90
 
95
91
  let scheduleIntervalCfg = INNER_SCHEDULE_INTERVAL;
96
- if (typeof fatcmsScheduleService === "object") {
97
- scheduleIntervalCfg = fatcmsScheduleService
92
+ if (typeof fatcmsScheduleService === 'object') {
93
+ scheduleIntervalCfg = fatcmsScheduleService;
98
94
  }
99
95
 
100
96
  const keys = Object.keys(scheduleIntervalCfg);
101
97
  for (let i = 0; i < keys.length; i++) {
102
98
  const service = keys[i];
103
99
  const interval = scheduleIntervalCfg[service];
104
- if (typeof interval !== "number") {
105
- throw new Error('Invalid scheduleIntervalCfg ' + service + ", interval must be a number");
100
+ if (typeof interval !== 'number') {
101
+ throw new Error('Invalid scheduleIntervalCfg ' + service + ', interval must be a number');
106
102
  }
107
103
  SCHEDULE_QUEUE.setScheduleTask(service, interval);
108
104
  }
@@ -110,7 +106,4 @@ export class ContainerLifeCycle {
110
106
  await SCHEDULE_QUEUE.startScheduleLoop();
111
107
  logger.info('ContainerLifeCycle ==> onReady 启动定时任务 : ' + JSON.stringify(scheduleIntervalCfg));
112
108
  }
113
-
114
-
115
-
116
109
  }
@@ -8,7 +8,8 @@ import { UserAccountService } from '@/service/UserAccountService';
8
8
  import { RelatedType } from '@/service/curd/CurdMixUtils';
9
9
  import { BaseService } from '@/service/base/BaseService';
10
10
  import * as moment from 'moment';
11
-
11
+ import { CommonException } from '@/libs/crud-pro/exceptions';
12
+ import { RedisKeys } from '@/models/RedisKeys';
12
13
 
13
14
  export interface IExecuteSimpleSqlParams {
14
15
  updateCfg?: Record<string, IFuncCfgModel>;
@@ -29,6 +30,23 @@ export class BaseApiController extends BaseService {
29
30
  @Inject()
30
31
  protected userAccountService: UserAccountService;
31
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
+
32
50
  protected getUserSessionInfo() {
33
51
  if (!this.ctx.userSession) {
34
52
  return null;
@@ -78,8 +96,8 @@ export class BaseApiController extends BaseService {
78
96
  this.addWorkbenchBasicInfoCfgModel(cfgModel);
79
97
 
80
98
  //sys系统表都是标准的,都有modified_at字段。
81
- if(sqlSimpleName === KeysOfSimpleSQL.SIMPLE_UPDATE && body.data) {
82
- body.data['modified_at'] = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss.SSS');
99
+ if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_UPDATE && body.data) {
100
+ body.data['modified_at'] = moment(Date.now()).format('YYYY-MM-DD HH:mm:ss.SSS');
83
101
  }
84
102
 
85
103
  return await this.curdMixService.executeCrudByCfg(body, cfgModel);