midway-fatcms 0.0.1-beta.20 → 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 -141
  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 -72
  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 -228
  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 -77
  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 -0
  181. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -0
  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 -226
  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 -213
  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 +25 -0
  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 +5 -4
  355. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +9 -14
  356. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -85
  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 +26 -0
  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 +20 -3
  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 -226
  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,187 +1,187 @@
1
- import { Inject, Provide } from '@midwayjs/core';
2
- import { Context } from '@midwayjs/koa';
3
- import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
4
- import { SystemTables} from '@/models/SystemTables';
5
- import { LRUCache } from 'lru-cache';
6
- import { BizException } from '@/models/devops';
7
- import { CurdMixService } from '../curd/CurdMixService';
8
- import { ISysAnyApiEntity } from '@/models/SystemEntities';
9
- import { AnyApiSandboxService, IRunInSandboxParams } from './AnyApiSandboxService';
10
- import { parseJsonObject } from '@/libs/utils/functions';
11
- import * as _ from 'lodash';
12
- import { MixinUtils } from '@/libs/crud-pro/utils/MixinUtils';
13
- import { WorkbenchService } from '../WorkbenchService';
14
- import { validateByCfgString } from '@/libs/crud-pro/utils/ValidateUtils';
15
- import { API_BASE_TYPE, ApiBaseService } from '../base/ApiBaseService';
16
- import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
17
-
18
- const lruCache = new LRUCache<string, any>({
19
- max: 500,
20
- ttl: 1000 * 60,
21
- ttlAutopurge: true,
22
- });
23
-
24
- @Provide()
25
- export class AnyApiService extends ApiBaseService {
26
- @Inject()
27
- protected ctx: Context;
28
-
29
- @Inject()
30
- private curdMixService: CurdMixService;
31
-
32
- @Inject()
33
- private anyApiSandboxService: AnyApiSandboxService;
34
-
35
- @Inject()
36
- protected workbenchService: WorkbenchService;
37
-
38
- async executeAnyApiMethod(methodCode: string, headers: any, body: any, query: any) {
39
- const anyApi = await this.getAnyApiMethod(methodCode);
40
- if (!anyApi || anyApi.status !== 1) {
41
- throw new BizException('接口不存在或已下线:' + methodCode);
42
- }
43
-
44
- const isSupport = await this.workbenchService.isSupportCurrentWorkbench(anyApi.workbench_code_array);
45
- if (!isSupport) {
46
- throw new BizException('此接口不支持在当前站点打开:' + methodCode);
47
- }
48
-
49
- await super.beforeCheckApiAccessibility(API_BASE_TYPE.PROXY_API, anyApi);
50
-
51
- if (!anyApi.func_code) {
52
- throw new BizException('没有配置代码:' + methodCode);
53
- }
54
-
55
- if (!this.checkFuncCode(anyApi.func_code)) {
56
- throw new BizException('接口代码校验失败:不满足形式: class HttpController { async handleRequest(params){} }; ');
57
- }
58
-
59
- const allParams: IRunInSandboxParams = { headers, body, query };
60
- allParams.params = this.toAnyApiParams(anyApi, allParams); // 组合参数
61
-
62
- // 执行代码
63
- const funcRes = await this.executeFunctionCode(anyApi, allParams);
64
- return funcRes;
65
- }
66
-
67
- private async getAnyApiMethod(methodCode: string): Promise<ISysAnyApiEntity> {
68
-
69
- // 开发环境,不使用缓存
70
- if (this.isEnableDebug()) {
71
- return this._getAnyApiMethod(methodCode);
72
- }
73
-
74
- // 线上环境可以使用缓存
75
- let anyApi = lruCache.get(methodCode);
76
- if (!anyApi) {
77
- anyApi = await this._getAnyApiMethod(methodCode);
78
- lruCache.set(methodCode, anyApi);
79
- }
80
- return anyApi;
81
- }
82
-
83
- private async _getAnyApiMethod(methodCode: string): Promise<ISysAnyApiEntity> {
84
- const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
85
-
86
- const res = await this.curdMixService.executeCrudByCfg(
87
- { condition: { method: methodCode } },
88
- {
89
- sqlTable: SystemTables.sys_anyapi,
90
- method: `get_sys_anyapi_${methodCode}`,
91
- sqlSimpleName: KeysOfSimpleSQL.SIMPLE_QUERY_ONE,
92
- sqlDatabase: SystemDbName,
93
- sqlDbType: SystemDbType,
94
- updateCfg: {},
95
- }
96
- );
97
- const obj: ISysAnyApiEntity = res.getOneObj();
98
- if (!obj) {
99
- return null;
100
- }
101
- obj.parsedOthers = parseJsonObject(obj.others);
102
- return obj;
103
- }
104
-
105
- /**
106
- * 构造参数
107
- * @param anyApi
108
- * @param allParams
109
- * @private
110
- */
111
- private toAnyApiParams(anyApi: ISysAnyApiEntity, allParams: IRunInSandboxParams): any {
112
- if (!anyApi.req_params) {
113
- return {};
114
- }
115
-
116
- const configs = anyApi.parsedOthers?.req_params || [];
117
- const params = {};
118
- for (let i = 0; i < configs.length; i++) {
119
- const { name, fromType, fromKey, validate_required, validate_cfg_list, valueType, defaultValue } = configs[i];
120
- const value = _.get(allParams, [fromType, fromKey], defaultValue);
121
- if (validate_required && MixinUtils.isEmpty(value)) {
122
- throw new BizException(`参数校验失败:${name} 不能为空`);
123
- }
124
-
125
- // 参数校验
126
- if (Array.isArray(validate_cfg_list)) {
127
- for (let j = 0; j < validate_cfg_list.length; j++) {
128
- const validateCfg = validate_cfg_list[j];
129
- validateByCfgString(validateCfg, value, name);
130
- }
131
- }
132
-
133
- // 格式转换
134
- params[name] = MixinUtils.parseValueByType(value, valueType);
135
- }
136
- return params;
137
- }
138
-
139
- /**
140
- * 运行代码
141
- * @param anyApiEntity
142
- * @param allParams
143
- * @private
144
- */
145
- private async executeFunctionCode(anyApiEntity: ISysAnyApiEntity, allParams: IRunInSandboxParams): Promise<any> {
146
- return this.anyApiSandboxService.runInSandbox(anyApiEntity, allParams);
147
- }
148
-
149
- private checkFuncCode(func_code: string): boolean {
150
- if (!func_code) {
151
- return false;
152
- }
153
-
154
- const lineHasKey = (lineTrim: string, target: string): boolean => {
155
- const words = lineTrim.split(/[\s{}();]/);
156
- for (let i = 0; i < words.length; i++) {
157
- const word = words[i];
158
- if (word && word === target) {
159
- return true;
160
- }
161
- }
162
- return false;
163
- };
164
-
165
- let hasClass = false;
166
- let hasMethod = false;
167
- const lines = func_code.split('\n');
168
- for (let i = 0; i < lines.length; i++) {
169
- const line = lines[i];
170
- if (line) {
171
- const lineTrim = line.trim();
172
- if (lineTrim) {
173
- if (lineHasKey(lineTrim, 'class') && lineHasKey(lineTrim, 'HttpController')) {
174
- hasClass = true;
175
- }
176
- if (lineHasKey(lineTrim, 'async') && lineHasKey(lineTrim, 'handleRequest')) {
177
- hasMethod = true;
178
- }
179
- if (lineTrim.startsWith('handleRequest')) {
180
- hasMethod = true;
181
- }
182
- }
183
- }
184
- }
185
- return hasMethod && hasClass;
186
- }
187
- }
1
+ import { Inject, Provide } from '@midwayjs/core';
2
+ import { Context } from '@midwayjs/koa';
3
+ import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
4
+ import { SystemTables} from '@/models/SystemTables';
5
+ import { LRUCache } from 'lru-cache';
6
+ import { BizException } from '@/models/devops';
7
+ import { CurdMixService } from '../curd/CurdMixService';
8
+ import { ISysAnyApiEntity } from '@/models/SystemEntities';
9
+ import { AnyApiSandboxService, IRunInSandboxParams } from './AnyApiSandboxService';
10
+ import { parseJsonObject } from '@/libs/utils/functions';
11
+ import * as _ from 'lodash';
12
+ import { MixinUtils } from '@/libs/crud-pro/utils/MixinUtils';
13
+ import { WorkbenchService } from '../WorkbenchService';
14
+ import { validateByCfgString } from '@/libs/crud-pro/utils/ValidateUtils';
15
+ import { API_BASE_TYPE, ApiBaseService } from '../base/ApiBaseService';
16
+ import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
17
+
18
+ const lruCache = new LRUCache<string, any>({
19
+ max: 500,
20
+ ttl: 1000 * 60,
21
+ ttlAutopurge: true,
22
+ });
23
+
24
+ @Provide()
25
+ export class AnyApiService extends ApiBaseService {
26
+ @Inject()
27
+ protected ctx: Context;
28
+
29
+ @Inject()
30
+ private curdMixService: CurdMixService;
31
+
32
+ @Inject()
33
+ private anyApiSandboxService: AnyApiSandboxService;
34
+
35
+ @Inject()
36
+ protected workbenchService: WorkbenchService;
37
+
38
+ async executeAnyApiMethod(methodCode: string, headers: any, body: any, query: any) {
39
+ const anyApi = await this.getAnyApiMethod(methodCode);
40
+ if (!anyApi || anyApi.status !== 1) {
41
+ throw new BizException('接口不存在或已下线:' + methodCode);
42
+ }
43
+
44
+ const isSupport = await this.workbenchService.isSupportCurrentWorkbench(anyApi.workbench_code_array);
45
+ if (!isSupport) {
46
+ throw new BizException('此接口不支持在当前站点打开:' + methodCode);
47
+ }
48
+
49
+ await super.beforeCheckApiAccessibility(API_BASE_TYPE.PROXY_API, anyApi);
50
+
51
+ if (!anyApi.func_code) {
52
+ throw new BizException('没有配置代码:' + methodCode);
53
+ }
54
+
55
+ if (!this.checkFuncCode(anyApi.func_code)) {
56
+ throw new BizException('接口代码校验失败:不满足形式: class HttpController { async handleRequest(params){} }; ');
57
+ }
58
+
59
+ const allParams: IRunInSandboxParams = { headers, body, query };
60
+ allParams.params = this.toAnyApiParams(anyApi, allParams); // 组合参数
61
+
62
+ // 执行代码
63
+ const funcRes = await this.executeFunctionCode(anyApi, allParams);
64
+ return funcRes;
65
+ }
66
+
67
+ private async getAnyApiMethod(methodCode: string): Promise<ISysAnyApiEntity> {
68
+
69
+ // 开发环境,不使用缓存
70
+ if (this.isEnableDebug()) {
71
+ return this._getAnyApiMethod(methodCode);
72
+ }
73
+
74
+ // 线上环境可以使用缓存
75
+ let anyApi = lruCache.get(methodCode);
76
+ if (!anyApi) {
77
+ anyApi = await this._getAnyApiMethod(methodCode);
78
+ lruCache.set(methodCode, anyApi);
79
+ }
80
+ return anyApi;
81
+ }
82
+
83
+ private async _getAnyApiMethod(methodCode: string): Promise<ISysAnyApiEntity> {
84
+ const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
85
+
86
+ const res = await this.curdMixService.executeCrudByCfg(
87
+ { condition: { method: methodCode } },
88
+ {
89
+ sqlTable: SystemTables.sys_anyapi,
90
+ method: `get_sys_anyapi_${methodCode}`,
91
+ sqlSimpleName: KeysOfSimpleSQL.SIMPLE_QUERY_ONE,
92
+ sqlDatabase: SystemDbName,
93
+ sqlDbType: SystemDbType,
94
+ updateCfg: {},
95
+ }
96
+ );
97
+ const obj: ISysAnyApiEntity = res.getOneObj();
98
+ if (!obj) {
99
+ return null;
100
+ }
101
+ obj.parsedOthers = parseJsonObject(obj.others);
102
+ return obj;
103
+ }
104
+
105
+ /**
106
+ * 构造参数
107
+ * @param anyApi
108
+ * @param allParams
109
+ * @private
110
+ */
111
+ private toAnyApiParams(anyApi: ISysAnyApiEntity, allParams: IRunInSandboxParams): any {
112
+ if (!anyApi.req_params) {
113
+ return {};
114
+ }
115
+
116
+ const configs = anyApi.parsedOthers?.req_params || [];
117
+ const params = {};
118
+ for (let i = 0; i < configs.length; i++) {
119
+ const { name, fromType, fromKey, validate_required, validate_cfg_list, valueType, defaultValue } = configs[i];
120
+ const value = _.get(allParams, [fromType, fromKey], defaultValue);
121
+ if (validate_required && MixinUtils.isEmpty(value)) {
122
+ throw new BizException(`参数校验失败:${name} 不能为空`);
123
+ }
124
+
125
+ // 参数校验
126
+ if (Array.isArray(validate_cfg_list)) {
127
+ for (let j = 0; j < validate_cfg_list.length; j++) {
128
+ const validateCfg = validate_cfg_list[j];
129
+ validateByCfgString(validateCfg, value, name);
130
+ }
131
+ }
132
+
133
+ // 格式转换
134
+ params[name] = MixinUtils.parseValueByType(value, valueType);
135
+ }
136
+ return params;
137
+ }
138
+
139
+ /**
140
+ * 运行代码
141
+ * @param anyApiEntity
142
+ * @param allParams
143
+ * @private
144
+ */
145
+ private async executeFunctionCode(anyApiEntity: ISysAnyApiEntity, allParams: IRunInSandboxParams): Promise<any> {
146
+ return this.anyApiSandboxService.runInSandbox(anyApiEntity, allParams);
147
+ }
148
+
149
+ private checkFuncCode(func_code: string): boolean {
150
+ if (!func_code) {
151
+ return false;
152
+ }
153
+
154
+ const lineHasKey = (lineTrim: string, target: string): boolean => {
155
+ const words = lineTrim.split(/[\s{}();]/);
156
+ for (let i = 0; i < words.length; i++) {
157
+ const word = words[i];
158
+ if (word && word === target) {
159
+ return true;
160
+ }
161
+ }
162
+ return false;
163
+ };
164
+
165
+ let hasClass = false;
166
+ let hasMethod = false;
167
+ const lines = func_code.split('\n');
168
+ for (let i = 0; i < lines.length; i++) {
169
+ const line = lines[i];
170
+ if (line) {
171
+ const lineTrim = line.trim();
172
+ if (lineTrim) {
173
+ if (lineHasKey(lineTrim, 'class') && lineHasKey(lineTrim, 'HttpController')) {
174
+ hasClass = true;
175
+ }
176
+ if (lineHasKey(lineTrim, 'async') && lineHasKey(lineTrim, 'handleRequest')) {
177
+ hasMethod = true;
178
+ }
179
+ if (lineTrim.startsWith('handleRequest')) {
180
+ hasMethod = true;
181
+ }
182
+ }
183
+ }
184
+ }
185
+ return hasMethod && hasClass;
186
+ }
187
+ }
@@ -10,8 +10,10 @@ import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
10
10
  import { errorToString } from '@/libs/utils/errorToString';
11
11
  import { ANONYMOUS_CONTEXT } from '@/schedule';
12
12
  import { RedisKeys } from '@/models/RedisKeys';
13
+ import { getCurrentFullMoment } from '@/libs/utils/functions';
14
+ import { ExportExcelAsyncTaskHandler } from './handler/ExportExcelAsyncTaskHandler';
13
15
 
14
- const END_STATUS_LIST = [SysAsyncTaskStatus.SUCCEEDED, SysAsyncTaskStatus.FAILED, SysAsyncTaskStatus.PART_SUCCEEDED];
16
+ const END_STATUS_LIST = [SysAsyncTaskStatus.PART_SUCCEEDED, SysAsyncTaskStatus.SUCCEEDED, SysAsyncTaskStatus.FAILED, SysAsyncTaskStatus.CANCELLED, SysAsyncTaskStatus.PAUSED];
15
17
 
16
18
  class AsyncTaskRunner {
17
19
  isBusy = false;
@@ -27,8 +29,15 @@ class AsyncTaskRunner {
27
29
  for (let i = 0; i < taskList.length; i++) {
28
30
  const taskElement = taskList[i];
29
31
  taskElement.task_status = SysAsyncTaskStatus.RUNNING;
30
-
32
+
31
33
  try {
34
+ // 1. 更新当前这个任务的状态
35
+ await this.updateTaskStatus(taskElement, {
36
+ task_status: taskElement.task_status,
37
+ started_at: getCurrentFullMoment(),
38
+ updated_at: getCurrentFullMoment(),
39
+ });
40
+
32
41
  // 任务状态的设置在自定义的执行器里面。
33
42
  await this.executeTask(taskElement);
34
43
 
@@ -36,16 +45,18 @@ class AsyncTaskRunner {
36
45
  if (!END_STATUS_LIST.includes(taskElement.task_status)) {
37
46
  taskElement.task_status = SysAsyncTaskStatus.SUCCEEDED;
38
47
  }
39
-
40
48
  } catch (error) {
41
49
  taskElement.task_status = SysAsyncTaskStatus.FAILED;
42
50
  taskElement.error_message = errorToString(error);
43
51
  }
44
52
 
45
53
  try {
54
+ // 2. 更新当前这个任务的状态
46
55
  await this.updateTaskStatus(taskElement, {
47
56
  task_status: taskElement.task_status,
48
57
  error_message: taskElement.error_message,
58
+ updated_at: getCurrentFullMoment(),
59
+ completed_at: getCurrentFullMoment(),
49
60
  });
50
61
  } catch (error) {
51
62
  ANONYMOUS_CONTEXT.getApp().getCoreLogger().error('executeTaskList error', error);
@@ -113,11 +124,17 @@ class AsyncTaskRunner {
113
124
  */
114
125
  export const ASYNC_TASK_RUNNER = new AsyncTaskRunner();
115
126
 
127
+ //内置的异步任务处理器:EXCEL导出
128
+ ASYNC_TASK_RUNNER.taskHandlerMap.set('EXCEL_EXPORT', new ExportExcelAsyncTaskHandler());
129
+
116
130
  /**
117
131
  * Redis锁
118
132
  */
119
133
  const ASYNC_TASK_LOCK = RedisKeys.ASYNC_TASK_LOCK;
120
134
 
135
+ /**
136
+ * 上次检查异步任务的时间点
137
+ */
121
138
  const ASYNC_TASK_RUNTIME_OBJ = {
122
139
  LAST_CHECK_ASYNC_TASK_UPDATE_TIME: 0,
123
140
  };
@@ -0,0 +1,11 @@
1
+ export interface IExcelHeaderInfo {
2
+ title: string;
3
+ dataIndex: string;
4
+ }
5
+
6
+ export interface IExcelAsyncTaskHandler {
7
+ getExcelHeader(): Promise<IExcelHeaderInfo[]>;
8
+ getPageSize(): Promise<number>;
9
+ getTotalCount(): Promise<number>;
10
+ getExcelDataList(pageNo: number, pageSize: number): Promise<any[]>;
11
+ }
@@ -0,0 +1,224 @@
1
+ import { IMidwayKoaContext } from '@midwayjs/koa';
2
+ import { ISysAsyncTaskHandler, SysAsyncTaskContext } from '@/models/AsyncTaskModel';
3
+ import { ANONYMOUS_CONTEXT } from '@/schedule';
4
+ import { IExcelHeaderInfo, IExcelAsyncTaskHandler } from './ExcelInfoModel';
5
+ import { SysAsyncFileFormat } from '@/models/AsyncTaskModel';
6
+ import { ExportExcelByStdCrudHandler } from './ExportExcelByStdCrudHandler';
7
+ import { ExportExcelByInnerHttpHandler } from './ExportExcelByInnerHttpHandler';
8
+ import { IStdCrudExportInputParams, StdCrudExportInputParamsAppType } from '@/models/bizmodels';
9
+
10
+ import * as _ from 'lodash';
11
+ import * as fastcsv from 'fast-csv';
12
+ import * as fs from 'node:fs';
13
+ import * as fs2 from 'node:fs/promises';
14
+ import * as path from 'node:path';
15
+ import { parseJsonObject } from '@/libs/utils/functions';
16
+ import { UserSessionInfo } from '@/models/userSession';
17
+
18
+ const indexRef = { current: 0 };
19
+
20
+ async function createFileFolder(distFileFolder: string) {
21
+ try {
22
+ await fs2.access(distFileFolder);
23
+ } catch (e) {
24
+ await fs2.mkdir(distFileFolder, { recursive: true });
25
+ }
26
+ }
27
+
28
+ function getExcelAsyncTaskHandler(asyncTaskContext: SysAsyncTaskContext, ctx: IMidwayKoaContext): IExcelAsyncTaskHandler {
29
+ const inputParams: IStdCrudExportInputParams = parseJsonObject(asyncTaskContext?.task?.input_params);
30
+ if (inputParams && inputParams.appType === StdCrudExportInputParamsAppType.STD_CRUD) {
31
+ return new ExportExcelByStdCrudHandler(asyncTaskContext, inputParams, ctx);
32
+ }
33
+ if (inputParams && inputParams.appType === StdCrudExportInputParamsAppType.INNER_HTTP) {
34
+ return new ExportExcelByInnerHttpHandler(asyncTaskContext, inputParams, ctx);
35
+ }
36
+ throw new Error('[getExcelAsyncTaskHandler]appType不支持');
37
+ }
38
+
39
+ /**
40
+ * 多实例,每个任务一个实例。
41
+ * 导出EXCEL异步任务:
42
+ */
43
+ class ExportExcelAsyncTask {
44
+ protected asyncTaskContext: SysAsyncTaskContext;
45
+ protected ctx: IMidwayKoaContext;
46
+ protected headerColumns: IExcelHeaderInfo[];
47
+ protected excelAsyncTaskHandler: IExcelAsyncTaskHandler;
48
+
49
+ constructor(asyncTaskContext: SysAsyncTaskContext, ctx: IMidwayKoaContext) {
50
+ this.asyncTaskContext = asyncTaskContext;
51
+ this.ctx = ctx;
52
+ this.excelAsyncTaskHandler = getExcelAsyncTaskHandler(asyncTaskContext, ctx);
53
+ }
54
+
55
+ private getDistFileFolder() {
56
+ const app = ANONYMOUS_CONTEXT.getApp();
57
+ const config = app.getConfig();
58
+ const fatcmsExportExcelTmpFilePath = config.fatcmsExportExcelTmpFilePath;
59
+ if (!fatcmsExportExcelTmpFilePath) {
60
+ return path.join(__dirname, '../../tmp');
61
+ }
62
+ return fatcmsExportExcelTmpFilePath;
63
+ }
64
+
65
+ async executeWithContext() {
66
+ this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext start');
67
+
68
+ const pageSize = await this.excelAsyncTaskHandler.getPageSize();
69
+
70
+ const fileName = await this.getExcelFileName(); // 文件名
71
+ const distFileFolder = this.getDistFileFolder();
72
+ await createFileFolder(distFileFolder);
73
+ const diskFilePath = path.resolve(distFileFolder, fileName); // 磁盘文件路径
74
+
75
+ const totalCount = await this.getTotalCount();
76
+
77
+ await this.asyncTaskContext.updateTaskStatus({
78
+ output_total_records: totalCount,
79
+ output_file_format: SysAsyncFileFormat.CSV,
80
+ output_file_path: diskFilePath,
81
+ });
82
+
83
+ this.headerColumns = await this.getExcelHeader();
84
+
85
+ const ws = fs.createWriteStream(diskFilePath, {
86
+ encoding: 'utf-8',
87
+ });
88
+
89
+ const csvStream = fastcsv.format({ writeHeaders: false, headers: false, delimiter: ',' });
90
+ csvStream.pipe(ws);
91
+ csvStream.write('\ufeff'); // 写入BOM头,解决中文乱码问题
92
+
93
+ csvStream.write(this.formatToCsvHeader(this.headerColumns));
94
+
95
+ let processed_records = 0;
96
+
97
+ if (typeof totalCount === 'number' && totalCount > 0) {
98
+ const batchCount = Math.ceil(totalCount / pageSize);
99
+ for (let i = 0; i < batchCount; i++) {
100
+ const num = await this.writeExcelBatchData(csvStream, i + 1, pageSize);
101
+ processed_records = processed_records + num;
102
+ const progress = Math.round((processed_records / totalCount) * 100);
103
+ await this.asyncTaskContext.updateTaskStatus({
104
+ processed_records,
105
+ progress,
106
+ });
107
+ }
108
+ }
109
+
110
+ csvStream.end();
111
+ ws.on('finish', async () => {
112
+ this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext finish');
113
+ const fsStat = await fs2.stat(diskFilePath);
114
+ const output_file_size = fsStat.size;
115
+ this.asyncTaskContext.updateTaskStatus({
116
+ output_file_size,
117
+ });
118
+ });
119
+ this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext end');
120
+ }
121
+
122
+ private formatToCsvHeader(headerColumns: IExcelHeaderInfo[]): string[] {
123
+ return headerColumns.map(item => {
124
+ return item.title;
125
+ });
126
+ }
127
+
128
+ private async writeExcelBatchData(csvStream: fastcsv.CsvFormatterStream<any, any>, pageNo: number, pageSize: number): Promise<number> {
129
+ const dataList: any[] = await this.getExcelDataList(pageNo, pageSize);
130
+ for (let i = 0; i < dataList.length; i++) {
131
+ const csvRow = this.formatToCsvRow(dataList[i]);
132
+ csvStream.write(csvRow);
133
+ }
134
+ return dataList.length;
135
+ }
136
+
137
+ private formatToCsvRow(rowObj: any): string[] {
138
+ return this.headerColumns.map(obj => {
139
+ const dataIndex = obj.dataIndex;
140
+ const value = _.get(rowObj, dataIndex);
141
+ if (typeof value === 'undefined' || value === null) {
142
+ return '';
143
+ }
144
+ if (typeof value !== 'string') {
145
+ // boolean , number
146
+ return '' + value;
147
+ }
148
+ return value;
149
+ });
150
+ }
151
+
152
+ /**
153
+ * 获取文件名
154
+ * @returns 文件名
155
+ */
156
+ private async getExcelFileName() {
157
+ indexRef.current = indexRef.current + 1;
158
+ if (indexRef.current > 100000) {
159
+ indexRef.current = 1;
160
+ }
161
+ const num = `${indexRef.current}`.padStart(10);
162
+ return `export_${Date.now()}_${num}.csv`;
163
+ }
164
+
165
+ /**
166
+ * 获取Excel的表头
167
+ * @returns
168
+ */
169
+ private async getExcelHeader(): Promise<IExcelHeaderInfo[]> {
170
+ return this.excelAsyncTaskHandler.getExcelHeader();
171
+ // const inputParams = parseJsonObject(this.asyncTaskContext?.task?.input_params);
172
+ // if (inputParams && inputParams.appType === 'STD_CRUD') {
173
+ // // const appCode = inputParams.appCode;
174
+ // console.log(this)
175
+ // }
176
+ // return [
177
+ // { title: 'ID', dataIndex: 'id' },
178
+ // { title: '姓名', dataIndex: 'name' },
179
+ // { title: '邮箱', dataIndex: 'email' }
180
+ // ]
181
+ }
182
+
183
+ /**
184
+ * 获取文件总数
185
+ */
186
+ private async getTotalCount(): Promise<number> {
187
+ const totalCount = await this.excelAsyncTaskHandler.getTotalCount();
188
+ // 最多导出10万条数据
189
+ return Math.min(totalCount, 10 * 10000);
190
+ }
191
+
192
+ /**
193
+ * 获取数据内容数组
194
+ * @param pageNo 当前页号,从1开始
195
+ * @param pageSize 每页获取的数量。
196
+ */
197
+ private async getExcelDataList(pageNo: number, pageSize: number): Promise<any[]> {
198
+ return this.excelAsyncTaskHandler.getExcelDataList(pageNo, pageSize);
199
+ // const dataList = [];
200
+ // for (var i = 0; i < pageSize; i++) {
201
+ // dataList.push({ id: i, name: 'nmae' + i, email: 'www.dss@dd.dom' })
202
+ // }
203
+ // return dataList;
204
+ }
205
+ }
206
+
207
+ /**
208
+ * 单例
209
+ */
210
+ export class ExportExcelAsyncTaskHandler implements ISysAsyncTaskHandler {
211
+ public async execute(asyncTaskContext: SysAsyncTaskContext): Promise<any> {
212
+ console.log('[ExportExcelAsyncTaskHandler] execute');
213
+ const res = await ANONYMOUS_CONTEXT.runServiceAtAnonymousContext(async (ctx: IMidwayKoaContext) => {
214
+ const createdUserSession = parseJsonObject(asyncTaskContext?.task?.created_user_session);
215
+ ctx.userSession = new UserSessionInfo(createdUserSession, false);
216
+ const task = new ExportExcelAsyncTask(asyncTaskContext, ctx);
217
+ return task.executeWithContext();
218
+ });
219
+ if (res.error) {
220
+ throw res.error;
221
+ }
222
+ return res.result;
223
+ }
224
+ }