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

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 (419) 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 +12 -8
  219. package/dist/models/RedisKeys.js +15 -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 +127 -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 +110 -110
  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 +216 -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 +9 -6
  367. package/src/models/RedisKeys.ts +11 -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 +7 -10
  380. package/src/service/EnumInfoService.ts +24 -28
  381. package/src/service/FileCenterService.ts +4 -9
  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/AnyApiService.ts +1 -2
  387. package/src/service/asyncTask/AsyncTaskRunnerService.ts +22 -11
  388. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  389. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
  390. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +147 -0
  391. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +138 -0
  392. package/src/service/base/ApiBaseService.ts +3 -3
  393. package/src/service/base/ApiRateLimiter.ts +59 -59
  394. package/src/service/base/BaseService.ts +100 -74
  395. package/src/service/base/RedisCacheService.ts +38 -38
  396. package/src/service/crudstd/CrudStdActionService.ts +27 -27
  397. package/src/service/crudstd/CrudStdConstant.ts +62 -62
  398. package/src/service/crudstd/CrudStdRelationService.ts +78 -78
  399. package/src/service/crudstd/CrudStdService.ts +283 -243
  400. package/src/service/curd/CrudProQuick.ts +11 -17
  401. package/src/service/curd/CurdMixByAccountService.ts +8 -9
  402. package/src/service/curd/CurdMixByDictService.ts +19 -24
  403. package/src/service/curd/CurdMixByLinkToCustomService.ts +10 -9
  404. package/src/service/curd/CurdMixBySysConfigService.ts +8 -13
  405. package/src/service/curd/CurdMixByWorkbenchService.ts +7 -8
  406. package/src/service/curd/CurdMixService.ts +37 -5
  407. package/src/service/curd/CurdMixUtils.ts +65 -45
  408. package/src/service/curd/CurdProService.ts +42 -48
  409. package/src/service/curd/fixCfgModel.ts +139 -139
  410. package/src/service/proxyapi/ProxyApiLoadService.ts +174 -174
  411. package/src/service/proxyapi/ProxyApiService.ts +262 -262
  412. package/src/service/proxyapi/ProxyApiUtils.ts +32 -32
  413. package/src/service/proxyapi/RouteHandler.ts +8 -8
  414. package/src/service/proxyapi/RouteTrie.ts +74 -74
  415. package/src/service/proxyapi/WeightedRandom.ts +37 -37
  416. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -44
  417. package/src/views/404_app.html +31 -31
  418. package/src/views/404_workbench.html +34 -34
  419. package/tsconfig.json +32 -32
@@ -1,10 +1,9 @@
1
- import {Inject, Provide} from '@midwayjs/core';
2
- import {Context} from '@midwayjs/koa';
3
- import {parseJsonObject} from '@/libs/utils/functions';
4
- import {ISessionInfo, SESSION_ID_KEY, sessionCookieCfg} from '@/models/userSession';
5
- import {RedisCacheService} from "./base/RedisCacheService";
6
- import {RedisKeys} from "@/models/RedisKeys";
7
-
1
+ import { Inject, Provide } from '@midwayjs/core';
2
+ import { Context } from '@midwayjs/koa';
3
+ import { parseJsonObject } from '@/libs/utils/functions';
4
+ import { ISessionInfo, SESSION_ID_KEY, sessionCookieCfg } from '@/models/userSession';
5
+ import { RedisCacheService } from './base/RedisCacheService';
6
+ import { RedisKeys } from '@/models/RedisKeys';
8
7
 
9
8
  function pickUserAvatar(avatar: any): string {
10
9
  if (!avatar) {
@@ -33,12 +32,11 @@ function pickUserAvatar(avatar: any): string {
33
32
  return null;
34
33
  }
35
34
 
36
-
37
35
  const SESSION_KEEP_TIME_SECOND: number = 3600 * 24 * 30;
38
36
 
39
- const toCacheKey = (sessionId: string): string =>{
37
+ const toCacheKey = (sessionId: string): string => {
40
38
  return `${RedisKeys.USER_SESSION_PREFIX}${sessionId}`;
41
- }
39
+ };
42
40
 
43
41
  @Provide()
44
42
  export class UserSessionService {
@@ -46,13 +44,12 @@ export class UserSessionService {
46
44
  private ctx: Context;
47
45
 
48
46
  @Inject()
49
- private redisCacheService: RedisCacheService
50
-
47
+ private redisCacheService: RedisCacheService;
51
48
 
52
49
  public async saveUserSession(sessionInfo: ISessionInfo) {
53
50
  sessionInfo.avatar = pickUserAvatar(sessionInfo.avatar);
54
51
  const sessionId = sessionInfo.sessionId;
55
- await this.redisCacheService.setJsonObject(toCacheKey(sessionId), sessionInfo, SESSION_KEEP_TIME_SECOND)
52
+ await this.redisCacheService.setJsonObject(toCacheKey(sessionId), sessionInfo, SESSION_KEEP_TIME_SECOND);
56
53
  }
57
54
 
58
55
  /**
@@ -60,14 +57,14 @@ export class UserSessionService {
60
57
  * @param sessionId
61
58
  */
62
59
  public async removeUserSession(sessionId: string) {
63
- return await this.redisCacheService.removeItem(toCacheKey(sessionId))
60
+ return await this.redisCacheService.removeItem(toCacheKey(sessionId));
64
61
  }
65
62
 
66
63
  private async getCurrentUserSessionForMiddleware1(sessionId: string): Promise<ISessionInfo> {
67
64
  if (!sessionId) {
68
65
  return null;
69
66
  }
70
- return await this.redisCacheService.getJsonObject(toCacheKey(sessionId))
67
+ return await this.redisCacheService.getJsonObject(toCacheKey(sessionId));
71
68
  }
72
69
 
73
70
  /**
@@ -78,5 +75,4 @@ export class UserSessionService {
78
75
  const sessionId = cookies.get(SESSION_ID_KEY, sessionCookieCfg);
79
76
  return this.getCurrentUserSessionForMiddleware1(sessionId);
80
77
  }
81
-
82
78
  }
@@ -1,16 +1,16 @@
1
1
  import { Inject, Provide } from '@midwayjs/core';
2
2
  import { Context } from '@midwayjs/koa';
3
- import { KeysOfSimpleSQL } from '../libs/crud-pro/models/keys';
4
- import { SystemTables} from '../models/SystemTables';
3
+ import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
4
+ import { SystemTables } from '@/models/SystemTables';
5
5
  import { BaseService } from './base/BaseService';
6
6
  // import { LRUCache } from 'lru-cache';
7
7
  import { CurdProService } from './curd/CurdProService';
8
- import { CommonException } from '../libs/crud-pro/exceptions';
9
- import { parseJsonObject } from '../libs/utils/functions';
10
- import { IWorkbenchEntity } from '../models/SystemEntities';
11
- import { IScheduleService } from '../interface';
12
- import { getDebugWorkbenchCode } from '../libs/utils/fatcms-request';
13
- import { MixinUtils } from '../libs/crud-pro/utils/MixinUtils';
8
+ import { CommonException } from '@/libs/crud-pro/exceptions';
9
+ import { parseJsonObject } from '@/libs/utils/functions';
10
+ import { IWorkbenchEntity } from '@/models/SystemEntities';
11
+ import { IScheduleService } from '@/interface';
12
+ import { getDebugWorkbenchCode } from '@/libs/utils/fatcms-request';
13
+ import { MixinUtils } from '@/libs/crud-pro/utils/MixinUtils';
14
14
  import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
15
15
  //
16
16
  // const lruCache = new LRUCache<string, any>({
@@ -24,7 +24,6 @@ const lruCache = new Map<string, any>();
24
24
  const CACHE_KEY_WORKBENCH_LIST = 'CACHE_KEY_WORKBENCH_LIST';
25
25
  const CACHE_KEY_DOMAIN_MAP = 'CACHE_KEY_DOMAIN_MAP';
26
26
 
27
-
28
27
  @Provide()
29
28
  export class WorkbenchService extends BaseService implements IScheduleService {
30
29
  @Inject()
@@ -43,10 +42,8 @@ export class WorkbenchService extends BaseService implements IScheduleService {
43
42
  }
44
43
 
45
44
  public async getAllWorkbenchInfoList(isForceRefresh?: boolean): Promise<IWorkbenchEntity[]> {
46
-
47
45
  const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
48
46
 
49
-
50
47
  let listData = lruCache.get(CACHE_KEY_WORKBENCH_LIST);
51
48
  if (!listData || isForceRefresh === true) {
52
49
  const reqJson = { condition: {}, pageSize: 1000, limit: 1000 };
@@ -70,7 +67,7 @@ export class WorkbenchService extends BaseService implements IScheduleService {
70
67
  const domainMap1 = MixinUtils.toMap(listData, (e: any) => e.workbench_domain); // 主域名。其他两个域名。
71
68
  const domainMap2 = MixinUtils.toMap(listData, (e: any) => e.workbench_domain2);
72
69
  const domainMap3 = MixinUtils.toMap(listData, (e: any) => e.workbench_domain3);
73
- domainMap = {...domainMap1, ...domainMap2, ...domainMap3};
70
+ domainMap = { ...domainMap1, ...domainMap2, ...domainMap3 };
74
71
  lruCache.set(CACHE_KEY_DOMAIN_MAP, domainMap);
75
72
  }
76
73
  return domainMap;
@@ -110,18 +107,21 @@ export class WorkbenchService extends BaseService implements IScheduleService {
110
107
  //正式环境: 根据域名获取站点配置
111
108
  const host = this.getCurrentHost();
112
109
  const domainMap = await this.getAllWorkbenchInfoMap();
113
- return domainMap[host];
110
+ const workbenchInfo = domainMap[host];
111
+ if (workbenchInfo) {
112
+ return workbenchInfo;
113
+ }
114
+ return domainMap['*']; // 最后兜底
114
115
  }
115
116
 
116
117
  private getCurrentHost(): string {
117
118
  const host = this.ctx.request.host;
118
119
  if (!host) {
119
- throw new CommonException('GET_CURRENT_HOST_ERROR','获取当前域名失败');
120
+ throw new CommonException('GET_CURRENT_HOST_ERROR', '获取当前域名失败');
120
121
  }
121
122
  return host;
122
123
  }
123
124
 
124
-
125
125
  public async isSupportCurrentWorkbench(workbench_code_array: string | string[]): Promise<boolean> {
126
126
  // 本地调试模式
127
127
  if (this.isEnableDebug() && this.isLocalEnv()) {
@@ -1,7 +1,7 @@
1
1
  import { Inject, Provide } from '@midwayjs/core';
2
2
  import { Context } from '@midwayjs/koa';
3
3
  import { KeysOfSimpleSQL } from '@/libs/crud-pro/models/keys';
4
- import { SystemTables} from '@/models/SystemTables';
4
+ import { SystemTables } from '@/models/SystemTables';
5
5
  import { LRUCache } from 'lru-cache';
6
6
  import { BizException } from '@/models/devops';
7
7
  import { CurdMixService } from '../curd/CurdMixService';
@@ -65,7 +65,6 @@ export class AnyApiService extends ApiBaseService {
65
65
  }
66
66
 
67
67
  private async getAnyApiMethod(methodCode: string): Promise<ISysAnyApiEntity> {
68
-
69
68
  // 开发环境,不使用缓存
70
69
  if (this.isEnableDebug()) {
71
70
  return this._getAnyApiMethod(methodCode);
@@ -10,14 +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 = [
15
- SysAsyncTaskStatus.PART_SUCCEEDED,
16
- SysAsyncTaskStatus.SUCCEEDED,
17
- SysAsyncTaskStatus.FAILED,
18
- SysAsyncTaskStatus.CANCELLED,
19
- SysAsyncTaskStatus.PAUSED,
20
- ];
16
+ const END_STATUS_LIST = [SysAsyncTaskStatus.PART_SUCCEEDED, SysAsyncTaskStatus.SUCCEEDED, SysAsyncTaskStatus.FAILED, SysAsyncTaskStatus.CANCELLED, SysAsyncTaskStatus.PAUSED];
21
17
 
22
18
  class AsyncTaskRunner {
23
19
  isBusy = false;
@@ -35,6 +31,13 @@ class AsyncTaskRunner {
35
31
  taskElement.task_status = SysAsyncTaskStatus.RUNNING;
36
32
 
37
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
+
38
41
  // 任务状态的设置在自定义的执行器里面。
39
42
  await this.executeTask(taskElement);
40
43
 
@@ -42,19 +45,21 @@ class AsyncTaskRunner {
42
45
  if (!END_STATUS_LIST.includes(taskElement.task_status)) {
43
46
  taskElement.task_status = SysAsyncTaskStatus.SUCCEEDED;
44
47
  }
45
-
46
48
  } catch (error) {
47
49
  taskElement.task_status = SysAsyncTaskStatus.FAILED;
48
50
  taskElement.error_message = errorToString(error);
49
51
  }
50
52
 
51
53
  try {
54
+ // 2. 更新当前这个任务的状态
52
55
  await this.updateTaskStatus(taskElement, {
53
56
  task_status: taskElement.task_status,
54
57
  error_message: taskElement.error_message,
58
+ updated_at: getCurrentFullMoment(),
59
+ completed_at: getCurrentFullMoment(),
55
60
  });
56
61
  } catch (error) {
57
- ANONYMOUS_CONTEXT.getApp().getCoreLogger().error('executeTaskList error', error);
62
+ ANONYMOUS_CONTEXT.getApp().getCoreLogger().error('[AsyncTaskRunner] executeTaskList error', error);
58
63
  }
59
64
  }
60
65
 
@@ -119,11 +124,17 @@ class AsyncTaskRunner {
119
124
  */
120
125
  export const ASYNC_TASK_RUNNER = new AsyncTaskRunner();
121
126
 
127
+ //内置的异步任务处理器:EXCEL导出
128
+ ASYNC_TASK_RUNNER.taskHandlerMap.set('EXCEL_EXPORT', new ExportExcelAsyncTaskHandler());
129
+
122
130
  /**
123
131
  * Redis锁
124
132
  */
125
133
  const ASYNC_TASK_LOCK = RedisKeys.ASYNC_TASK_LOCK;
126
134
 
135
+ /**
136
+ * 上次检查异步任务的时间点
137
+ */
127
138
  const ASYNC_TASK_RUNTIME_OBJ = {
128
139
  LAST_CHECK_ASYNC_TASK_UPDATE_TIME: 0,
129
140
  };
@@ -194,7 +205,7 @@ export class AsyncTaskRunnerService extends BaseService implements IScheduleServ
194
205
 
195
206
  // 开始执行。
196
207
  ASYNC_TASK_RUNNER.executeTaskList(taskList).then(() => {
197
- console.log('ASYNC_TASK_RUNNER finished taskIds ==> ' + JSON.stringify(taskIds));
208
+ console.log('[AsyncTaskRunnerService] ASYNC_TASK_RUNNER finished taskIds ==> ' + JSON.stringify(taskIds));
198
209
  });
199
210
  }
200
211
 
@@ -220,7 +231,7 @@ export class AsyncTaskRunnerService extends BaseService implements IScheduleServ
220
231
  try {
221
232
  await this.fetchPendingTasks();
222
233
  } catch (e) {
223
- console.error('fetchPendingTasks error', errorToString(e));
234
+ console.error('[AsyncTaskRunnerService] fetchPendingTasks error', errorToString(e));
224
235
  }
225
236
 
226
237
  await this.redisService.del(ASYNC_TASK_LOCK);
@@ -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,245 @@
1
+ import { IMidwayKoaContext } from '@midwayjs/koa';
2
+ import { ISysAsyncTaskHandler, SysAsyncTaskContext, SysAsyncTaskStatus } 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
+ import { errorToString } from '@/libs/utils/errorToString';
18
+
19
+ const indexRef = { current: 0 };
20
+
21
+ async function createFileFolder(distFileFolder: string) {
22
+ try {
23
+ await fs2.access(distFileFolder);
24
+ } catch (e) {
25
+ await fs2.mkdir(distFileFolder, { recursive: true });
26
+ }
27
+ }
28
+
29
+ function getExcelAsyncTaskHandler(asyncTaskContext: SysAsyncTaskContext, ctx: IMidwayKoaContext): IExcelAsyncTaskHandler {
30
+ const inputParams: IStdCrudExportInputParams = parseJsonObject(asyncTaskContext?.task?.input_params);
31
+ if (inputParams && inputParams.appType === StdCrudExportInputParamsAppType.STD_CRUD) {
32
+ return new ExportExcelByStdCrudHandler(asyncTaskContext, inputParams, ctx);
33
+ }
34
+ if (inputParams && inputParams.appType === StdCrudExportInputParamsAppType.INNER_HTTP) {
35
+ return new ExportExcelByInnerHttpHandler(asyncTaskContext, inputParams, ctx);
36
+ }
37
+ throw new Error('[getExcelAsyncTaskHandler]appType不支持;appType = ' + inputParams.appType);
38
+ }
39
+
40
+ /**
41
+ * 多实例,每个任务一个实例。
42
+ * 导出EXCEL异步任务:
43
+ */
44
+ class ExportExcelAsyncTask {
45
+ protected asyncTaskContext: SysAsyncTaskContext;
46
+ protected ctx: IMidwayKoaContext;
47
+ protected headerColumns: IExcelHeaderInfo[];
48
+ protected excelAsyncTaskHandler: IExcelAsyncTaskHandler;
49
+
50
+ constructor(asyncTaskContext: SysAsyncTaskContext, ctx: IMidwayKoaContext) {
51
+ this.asyncTaskContext = asyncTaskContext;
52
+ this.ctx = ctx;
53
+ this.excelAsyncTaskHandler = getExcelAsyncTaskHandler(asyncTaskContext, ctx);
54
+ }
55
+
56
+ private getDistFileFolder() {
57
+ const app = ANONYMOUS_CONTEXT.getApp();
58
+ const config = app.getConfig();
59
+ const fatcmsExportExcelTmpFilePath = config.fatcmsExportExcelTmpFilePath;
60
+ if (!fatcmsExportExcelTmpFilePath) {
61
+ return path.join(__dirname, '../../tmp');
62
+ }
63
+ return fatcmsExportExcelTmpFilePath;
64
+ }
65
+
66
+ async executeWithContext() {
67
+ const taskElement = this.asyncTaskContext.task;
68
+ const taskId = _.get(this.asyncTaskContext, 'task.id');
69
+
70
+ this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext start, taskId=' + taskId);
71
+
72
+ const pageSize = await this.excelAsyncTaskHandler.getPageSize();
73
+
74
+ const fileName = await this.getExcelFileName(); // 文件名
75
+ const distFileFolder = this.getDistFileFolder();
76
+ await createFileFolder(distFileFolder);
77
+ const diskFilePath = path.resolve(distFileFolder, fileName); // 磁盘文件路径
78
+
79
+ const totalCount = await this.getTotalCount();
80
+
81
+ await this.asyncTaskContext.updateTaskStatus({
82
+ output_total_records: totalCount,
83
+ output_file_format: SysAsyncFileFormat.CSV,
84
+ output_file_path: diskFilePath,
85
+ });
86
+
87
+ this.headerColumns = await this.getExcelHeader();
88
+
89
+ const ws = fs.createWriteStream(diskFilePath, {
90
+ encoding: 'utf-8',
91
+ });
92
+
93
+ const csvStream = fastcsv.format({ writeHeaders: false, headers: false, delimiter: ',' });
94
+ csvStream.pipe(ws);
95
+ csvStream.write('\ufeff'); // 写入BOM头,解决中文乱码问题
96
+
97
+ csvStream.write(this.formatToCsvHeader(this.headerColumns));
98
+
99
+ let processed_records = 0;
100
+
101
+ try {
102
+ if (typeof totalCount === 'number' && totalCount > 0) {
103
+ const batchCount = Math.ceil(totalCount / pageSize);
104
+ for (let i = 0; i < batchCount; i++) {
105
+ const num = await this.writeExcelBatchData(csvStream, i + 1, pageSize);
106
+ processed_records = processed_records + num;
107
+ const progress = Math.round((processed_records / totalCount) * 100);
108
+ await this.asyncTaskContext.updateTaskStatus({
109
+ processed_records,
110
+ progress,
111
+ });
112
+ }
113
+ }
114
+
115
+ taskElement.task_status = SysAsyncTaskStatus.SUCCEEDED;
116
+ } catch (error) {
117
+ taskElement.task_status = SysAsyncTaskStatus.FAILED;
118
+ taskElement.error_message = errorToString(error);
119
+ const progress = Math.round((processed_records / totalCount) * 100);
120
+ await this.asyncTaskContext.updateTaskStatus({
121
+ processed_records,
122
+ progress,
123
+ task_status: taskElement.task_status,
124
+ error_message: taskElement.error_message,
125
+ });
126
+ }
127
+
128
+ csvStream.end();
129
+ ws.on('finish', async () => {
130
+ this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext finish, taskId=' + taskId);
131
+ const fsStat = await fs2.stat(diskFilePath);
132
+ const output_file_size = fsStat.size;
133
+ this.asyncTaskContext.updateTaskStatus({
134
+ output_file_size,
135
+ });
136
+ });
137
+ this.ctx.logger.info('[ExportExcelAsyncTask] executeWithContext end, taskId=' + taskId);
138
+ }
139
+
140
+ private formatToCsvHeader(headerColumns: IExcelHeaderInfo[]): string[] {
141
+ return headerColumns.map(item => {
142
+ return item.title;
143
+ });
144
+ }
145
+
146
+ private async writeExcelBatchData(csvStream: fastcsv.CsvFormatterStream<any, any>, pageNo: number, pageSize: number): Promise<number> {
147
+ const dataList: any[] = await this.getExcelDataList(pageNo, pageSize);
148
+ for (let i = 0; i < dataList.length; i++) {
149
+ const csvRow = this.formatToCsvRow(dataList[i]);
150
+ csvStream.write(csvRow);
151
+ }
152
+ return dataList.length;
153
+ }
154
+
155
+ private formatToCsvRow(rowObj: any): string[] {
156
+ return this.headerColumns.map(obj => {
157
+ const dataIndex = obj.dataIndex;
158
+ const value = _.get(rowObj, dataIndex);
159
+ if (typeof value === 'undefined' || value === null) {
160
+ return '';
161
+ }
162
+ if (typeof value !== 'string') {
163
+ // boolean , number
164
+ return '' + value;
165
+ }
166
+ return value;
167
+ });
168
+ }
169
+
170
+ /**
171
+ * 获取文件名
172
+ * @returns 文件名
173
+ */
174
+ private async getExcelFileName() {
175
+ indexRef.current = indexRef.current + 1;
176
+ if (indexRef.current > 100000) {
177
+ indexRef.current = 1;
178
+ }
179
+ const num = `${indexRef.current}`.padStart(10);
180
+ return `export_${Date.now()}_${num}.csv`;
181
+ }
182
+
183
+ /**
184
+ * 获取Excel的表头
185
+ * @returns
186
+ */
187
+ private async getExcelHeader(): Promise<IExcelHeaderInfo[]> {
188
+ return this.excelAsyncTaskHandler.getExcelHeader();
189
+ // const inputParams = parseJsonObject(this.asyncTaskContext?.task?.input_params);
190
+ // if (inputParams && inputParams.appType === 'STD_CRUD') {
191
+ // // const appCode = inputParams.appCode;
192
+ // console.log(this)
193
+ // }
194
+ // return [
195
+ // { title: 'ID', dataIndex: 'id' },
196
+ // { title: '姓名', dataIndex: 'name' },
197
+ // { title: '邮箱', dataIndex: 'email' }
198
+ // ]
199
+ }
200
+
201
+ /**
202
+ * 获取文件总数
203
+ */
204
+ private async getTotalCount(): Promise<number> {
205
+ const totalCount = await this.excelAsyncTaskHandler.getTotalCount();
206
+ // 最多导出10万条数据
207
+ return Math.min(totalCount, 10 * 10000);
208
+ }
209
+
210
+ /**
211
+ * 获取数据内容数组
212
+ * @param pageNo 当前页号,从1开始
213
+ * @param pageSize 每页获取的数量。
214
+ */
215
+ private async getExcelDataList(pageNo: number, pageSize: number): Promise<any[]> {
216
+ return this.excelAsyncTaskHandler.getExcelDataList(pageNo, pageSize);
217
+ // const dataList = [];
218
+ // for (var i = 0; i < pageSize; i++) {
219
+ // dataList.push({ id: i, name: 'nmae' + i, email: 'www.dss@dd.dom' })
220
+ // }
221
+ // return dataList;
222
+ }
223
+ }
224
+
225
+ /**
226
+ * 单例
227
+ */
228
+ export class ExportExcelAsyncTaskHandler implements ISysAsyncTaskHandler {
229
+ public async execute(asyncTaskContext: SysAsyncTaskContext): Promise<any> {
230
+ const taskId = _.get(asyncTaskContext, 'task.id');
231
+
232
+ console.log('[ExportExcelAsyncTaskHandler] execute, taskId=>' + taskId);
233
+
234
+ const res = await ANONYMOUS_CONTEXT.runServiceAtAnonymousContext(async (ctx: IMidwayKoaContext) => {
235
+ const createdUserSession = parseJsonObject(asyncTaskContext?.task?.created_user_session);
236
+ ctx.userSession = new UserSessionInfo(createdUserSession, false);
237
+ const task = new ExportExcelAsyncTask(asyncTaskContext, ctx);
238
+ return task.executeWithContext();
239
+ });
240
+ if (res.error) {
241
+ throw res.error;
242
+ }
243
+ return res.result;
244
+ }
245
+ }
@@ -0,0 +1,147 @@
1
+ import * as _ from 'lodash';
2
+ import axios from 'axios';
3
+ import { IMidwayKoaContext } from '@midwayjs/koa';
4
+ import { IExcelAsyncTaskHandler, IExcelHeaderInfo } from './ExcelInfoModel';
5
+ import { SysAsyncTaskContext } from '@/models/AsyncTaskModel';
6
+ import { IStdCrudExportInputParams, ITableProQueryParams } from '@/models/bizmodels';
7
+ import { IRequestModel } from '@/libs/crud-pro/interfaces';
8
+ import { ANONYMOUS_CONTEXT } from '@/schedule';
9
+
10
+ function pickData(a: any, key: string) {
11
+ if (a && typeof a.getResModel === 'function') {
12
+ const s = a.getResModel();
13
+ return s[key];
14
+ }
15
+ if (!a) {
16
+ throw 'ExportExcelByInnerHttpHandler返回数据不存在';
17
+ }
18
+ return _.get(a, `data.${key}`);
19
+ }
20
+
21
+ /**
22
+ * 多实例,每个任务一个实例。
23
+ * 导出Excel。请求任务级别的。
24
+ * 使用内部HTTP接口导出
25
+ */
26
+ class ExportExcelByInnerHttpHandler implements IExcelAsyncTaskHandler {
27
+ protected asyncTaskContext: SysAsyncTaskContext;
28
+ protected ctx: IMidwayKoaContext;
29
+ protected inputParams: IStdCrudExportInputParams;
30
+ protected appCode: string;
31
+ public constructor(asyncTaskContext: SysAsyncTaskContext, inputParams: IStdCrudExportInputParams, ctx: IMidwayKoaContext) {
32
+ this.ctx = ctx;
33
+ this.inputParams = inputParams;
34
+ this.asyncTaskContext = asyncTaskContext;
35
+ this.appCode = this.inputParams.appCode;
36
+ }
37
+
38
+ async getPageSize(): Promise<number> {
39
+ if (typeof this.inputParams.pageSize === 'number') {
40
+ return Math.min(this.inputParams.pageSize, 1000);
41
+ }
42
+ return 1000;
43
+ }
44
+
45
+ /**
46
+ * 获取Excel表的表头
47
+ * @returns 表头信息
48
+ */
49
+ async getExcelHeader(): Promise<IExcelHeaderInfo[]> {
50
+ const columns = this.inputParams.columns;
51
+ if (!columns) {
52
+ throw new Error('导出Excel的表头信息不存在');
53
+ }
54
+ if (!Array.isArray(columns) || columns.length === 0) {
55
+ throw new Error('导出Excel的表头信息不是数组');
56
+ }
57
+ return columns
58
+ .map(cc => {
59
+ let { title, dataIndex } = cc;
60
+ if (!dataIndex) {
61
+ return null;
62
+ }
63
+ if (!title) {
64
+ title = '字段_' + dataIndex;
65
+ }
66
+ return { title, dataIndex };
67
+ })
68
+ .filter(Boolean);
69
+ }
70
+
71
+ private async sendRequest(params: any): Promise<any> {
72
+ const port = ANONYMOUS_CONTEXT.getApp().getConfig().koa.port;
73
+ let queryApi = this.inputParams.innerHttpUrl; // 以斜杠开头
74
+ if (!queryApi.startsWith('/')) {
75
+ queryApi = '/' + queryApi;
76
+ }
77
+
78
+ params.runByExportExcel = true;
79
+
80
+ const response = await axios({
81
+ method: 'POST',
82
+ url: `http://127.0.0.1:${port}${queryApi}`,
83
+ data: params,
84
+ headers: this.inputParams.headers || {},
85
+ responseType: 'json',
86
+ validateStatus: () => true,
87
+ });
88
+ if (response.status !== 200) {
89
+ throw new Error('导出Excel请求错误失败,状态码:' + response.status);
90
+ }
91
+ return response.data;
92
+ }
93
+
94
+ /**
95
+ * 获取要导出的数量总数
96
+ * @returns 数据总量
97
+ */
98
+ async getTotalCount(): Promise<number> {
99
+ const selectedRowKeys: string[] | number[] = this.inputParams?.selectedRowKeys || [];
100
+ if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
101
+ return selectedRowKeys.length;
102
+ }
103
+
104
+ const lastQueryParams: ITableProQueryParams = this.inputParams?.lastQueryParams;
105
+ const res = await this.sendRequest({
106
+ condition: lastQueryParams?.condition || {},
107
+ orderBy: lastQueryParams?.orderBy,
108
+ pageSize: 1,
109
+ pageNo: 1,
110
+ });
111
+ return pickData(res, 'total_count');
112
+ }
113
+
114
+ /**
115
+ * 获取要导出Excel的数据的内容
116
+ * @param pageNo 页号,从1开始
117
+ * @param pageSize 每页数量
118
+ * @returns
119
+ */
120
+ async getExcelDataList(pageNo: number, pageSize: number): Promise<any[]> {
121
+ const selectedRowKeys: string[] | number[] = this.inputParams?.selectedRowKeys || [];
122
+ const lastQueryParams: ITableProQueryParams = this.inputParams?.lastQueryParams;
123
+ const primaryKey: string = this.inputParams.primaryKey || 'id';
124
+
125
+ const params: IRequestModel = {
126
+ condition: lastQueryParams?.condition || {},
127
+ pageSize: pageSize,
128
+ pageNo: pageNo,
129
+ orderBy: lastQueryParams?.orderBy,
130
+ };
131
+
132
+ if (Array.isArray(selectedRowKeys) && selectedRowKeys.length > 0) {
133
+ params.condition[primaryKey] = {
134
+ $in: selectedRowKeys,
135
+ };
136
+ }
137
+ const res = await this.sendRequest({
138
+ condition: lastQueryParams?.condition || {},
139
+ orderBy: lastQueryParams?.orderBy,
140
+ pageSize: pageSize,
141
+ pageNo: pageNo,
142
+ });
143
+ return pickData(res, 'rows');
144
+ }
145
+ }
146
+
147
+ export { ExportExcelByInnerHttpHandler };