midway-fatcms 0.0.1-beta.7 → 0.0.1-beta.70

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 (530) hide show
  1. package/.eslintrc.json +14 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +8 -1
  4. package/dist/config/config.default.d.ts +3 -3
  5. package/dist/config/config.default.js +171 -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 -6
  10. package/dist/configuration.js +113 -89
  11. package/dist/controller/base/BaseApiController.d.ts +42 -31
  12. package/dist/controller/base/BaseApiController.js +189 -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 -0
  16. package/dist/controller/gateway/AsyncTaskController.js +181 -0
  17. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
  18. package/dist/controller/gateway/CrudMtdGatewayController.js +122 -116
  19. package/dist/controller/gateway/CrudStdGatewayController.d.ts +39 -38
  20. package/dist/controller/gateway/CrudStdGatewayController.js +149 -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 +28 -25
  24. package/dist/controller/gateway/FileController.js +145 -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 +33 -27
  28. package/dist/controller/gateway/PublicApiController.js +201 -167
  29. package/dist/controller/gateway/StaticController.d.ts +23 -24
  30. package/dist/controller/gateway/StaticController.js +286 -285
  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 +72 -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 +12 -10
  40. package/dist/controller/manage/AppMangeApi.js +101 -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 +46 -38
  48. package/dist/controller/manage/CrudStandardDesignApi.js +395 -354
  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 -178
  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 +12 -11
  68. package/dist/controller/manage/SysConfigMangeApi.js +133 -126
  69. package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
  70. package/dist/controller/manage/SystemInfoManageApi.js +72 -66
  71. package/dist/controller/manage/UserAccountManageApi.d.ts +16 -14
  72. package/dist/controller/manage/UserAccountManageApi.js +153 -124
  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 -37
  76. package/dist/controller/myinfo/AuthController.js +136 -189
  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 +12 -11
  80. package/dist/controller/render/AppRenderController.js +87 -87
  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 +104 -94
  88. package/dist/index.js +122 -112
  89. package/dist/interface.d.ts +29 -27
  90. package/dist/interface.js +3 -3
  91. package/dist/libs/crud-pro/CrudPro.d.ts +37 -36
  92. package/dist/libs/crud-pro/CrudPro.js +136 -131
  93. package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
  94. package/dist/libs/crud-pro/defaultConfigs.js +15 -13
  95. package/dist/libs/crud-pro/exceptions.d.ts +106 -104
  96. package/dist/libs/crud-pro/exceptions.js +119 -117
  97. package/dist/libs/crud-pro/interfaces.d.ts +166 -157
  98. package/dist/libs/crud-pro/interfaces.js +12 -12
  99. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -42
  100. package/dist/libs/crud-pro/models/ExecuteContext.js +79 -79
  101. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -31
  102. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -64
  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 -0
  110. package/dist/libs/crud-pro/models/ResModel.js +2 -0
  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 +23 -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 +30 -29
  118. package/dist/libs/crud-pro/models/Transaction.js +74 -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 +110 -106
  126. package/dist/libs/crud-pro/models/keys.js +154 -149
  127. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -10
  128. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -61
  129. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
  130. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +125 -112
  131. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
  132. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -227
  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 +355 -342
  139. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
  140. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -174
  141. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
  142. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +339 -333
  143. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -28
  144. package/dist/libs/crud-pro/services/CrudProServiceBase.js +88 -78
  145. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -8
  146. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +78 -53
  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 -29
  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 +54 -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 +35 -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 +14 -11
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +14 -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 +69 -19
  189. package/dist/libs/global-config/global-config.js +36 -25
  190. package/dist/libs/utils/AsymmetricCrypto.d.ts +76 -0
  191. package/dist/libs/utils/AsymmetricCrypto.js +261 -0
  192. package/dist/libs/utils/base64.d.ts +9 -0
  193. package/dist/libs/utils/base64.js +42 -0
  194. package/dist/libs/utils/common-dto.d.ts +18 -18
  195. package/dist/libs/utils/common-dto.js +40 -40
  196. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  197. package/dist/libs/utils/crypto-utils.js +46 -46
  198. package/dist/libs/utils/errorToString.d.ts +2 -0
  199. package/dist/libs/utils/errorToString.js +57 -0
  200. package/dist/libs/utils/fatcms-request.d.ts +30 -30
  201. package/dist/libs/utils/fatcms-request.js +104 -104
  202. package/dist/libs/utils/format-url.d.ts +2 -0
  203. package/dist/libs/utils/format-url.js +13 -0
  204. package/dist/libs/utils/functions.d.ts +5 -4
  205. package/dist/libs/utils/functions.js +72 -63
  206. package/dist/libs/utils/ordernum-utils.d.ts +2 -2
  207. package/dist/libs/utils/ordernum-utils.js +13 -13
  208. package/dist/libs/utils/parseConfig.d.ts +8 -7
  209. package/dist/libs/utils/parseConfig.js +47 -44
  210. package/dist/libs/utils/parseCreateSql.d.ts +10 -5
  211. package/dist/libs/utils/parseCreateSql.js +87 -86
  212. package/dist/libs/utils/render-utils.d.ts +37 -28
  213. package/dist/libs/utils/render-utils.js +154 -135
  214. package/dist/middleware/forbidden.middleware.d.ts +10 -10
  215. package/dist/middleware/forbidden.middleware.js +54 -70
  216. package/dist/middleware/global.middleware.d.ts +10 -10
  217. package/dist/middleware/global.middleware.js +273 -246
  218. package/dist/middleware/permission.middleware.d.ts +18 -18
  219. package/dist/middleware/permission.middleware.js +74 -74
  220. package/dist/middleware/rediscache.middleware.d.ts +3 -0
  221. package/dist/middleware/rediscache.middleware.js +77 -0
  222. package/dist/middleware/redislock.middleware.d.ts +7 -0
  223. package/dist/middleware/redislock.middleware.js +72 -0
  224. package/dist/middleware/tx.middleware.d.ts +9 -9
  225. package/dist/middleware/tx.middleware.js +40 -40
  226. package/dist/models/AsyncTaskModel.d.ts +74 -0
  227. package/dist/models/AsyncTaskModel.js +31 -0
  228. package/dist/models/RedisKeys.d.ts +15 -0
  229. package/dist/models/RedisKeys.js +18 -0
  230. package/dist/models/SystemEntities.d.ts +117 -98
  231. package/dist/models/SystemEntities.js +17 -2
  232. package/dist/models/SystemPerm.d.ts +95 -95
  233. package/dist/models/SystemPerm.js +100 -100
  234. package/dist/models/SystemTables.d.ts +25 -24
  235. package/dist/models/SystemTables.js +28 -27
  236. package/dist/models/WorkbenchInfoTools.d.ts +7 -0
  237. package/dist/models/WorkbenchInfoTools.js +20 -0
  238. package/dist/models/bizmodels.d.ts +132 -69
  239. package/dist/models/bizmodels.js +54 -34
  240. package/dist/models/contextLogger.d.ts +27 -25
  241. package/dist/models/contextLogger.js +119 -112
  242. package/dist/models/devops.d.ts +12 -12
  243. package/dist/models/devops.js +19 -19
  244. package/dist/models/userSession.d.ts +64 -61
  245. package/dist/models/userSession.js +167 -165
  246. package/dist/schedule/anonymousContext.d.ts +14 -0
  247. package/dist/schedule/anonymousContext.js +61 -0
  248. package/dist/schedule/index.d.ts +4 -3
  249. package/dist/schedule/index.js +10 -69
  250. package/dist/schedule/runSchedule.d.ts +12 -0
  251. package/dist/schedule/runSchedule.js +68 -0
  252. package/dist/schedule/scheduleNames.d.ts +13 -0
  253. package/dist/schedule/scheduleNames.js +17 -0
  254. package/dist/service/AuthService.d.ts +71 -70
  255. package/dist/service/AuthService.js +270 -251
  256. package/dist/service/EnumInfoService.d.ts +31 -30
  257. package/dist/service/EnumInfoService.js +120 -126
  258. package/dist/service/FileCenterService.d.ts +43 -43
  259. package/dist/service/FileCenterService.js +351 -351
  260. package/dist/service/SysAppService.d.ts +14 -0
  261. package/dist/service/SysAppService.js +96 -0
  262. package/dist/service/SysConfigService.d.ts +10 -7
  263. package/dist/service/SysConfigService.js +64 -47
  264. package/dist/service/UserAccountService.d.ts +23 -23
  265. package/dist/service/UserAccountService.js +107 -107
  266. package/dist/service/UserSessionService.d.ts +43 -16
  267. package/dist/service/UserSessionService.js +163 -85
  268. package/dist/service/VisitStatService.d.ts +14 -14
  269. package/dist/service/VisitStatService.js +158 -167
  270. package/dist/service/WorkbenchService.d.ts +59 -20
  271. package/dist/service/WorkbenchService.js +249 -155
  272. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  273. package/dist/service/anyapi/AnyApiSandboxService.js +122 -122
  274. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  275. package/dist/service/anyapi/AnyApiService.js +181 -181
  276. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -0
  277. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -0
  278. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -0
  279. package/dist/service/asyncTask/AsyncTaskService.js +34 -0
  280. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
  281. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
  282. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
  283. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -0
  284. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
  285. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -0
  286. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
  287. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -0
  288. package/dist/service/base/ApiBaseService.d.ts +15 -15
  289. package/dist/service/base/ApiBaseService.js +50 -50
  290. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  291. package/dist/service/base/ApiRateLimiter.js +51 -51
  292. package/dist/service/base/BaseService.d.ts +41 -29
  293. package/dist/service/base/BaseService.js +101 -79
  294. package/dist/service/base/cache/CacheServiceFactory.d.ts +23 -0
  295. package/dist/service/base/cache/CacheServiceFactory.js +83 -0
  296. package/dist/service/base/cache/CtxCache.d.ts +18 -0
  297. package/dist/service/base/cache/CtxCache.js +37 -0
  298. package/dist/service/base/cache/DiskCache.d.ts +19 -0
  299. package/dist/service/base/cache/DiskCache.js +74 -0
  300. package/dist/service/base/cache/MemoryCache.d.ts +12 -0
  301. package/dist/service/base/cache/MemoryCache.js +58 -0
  302. package/dist/service/base/cache/NoneCache.d.ts +10 -0
  303. package/dist/service/base/cache/NoneCache.js +19 -0
  304. package/dist/service/base/cache/RedisCache.d.ts +14 -0
  305. package/dist/service/base/cache/RedisCache.js +31 -0
  306. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  307. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  308. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  309. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  310. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  311. package/dist/service/crudstd/CrudStdRelationService.js +121 -85
  312. package/dist/service/crudstd/CrudStdService.d.ts +60 -50
  313. package/dist/service/crudstd/CrudStdService.js +376 -186
  314. package/dist/service/curd/CrudProQuick.d.ts +50 -0
  315. package/dist/service/curd/CrudProQuick.js +163 -0
  316. package/dist/service/curd/CurdMixByAccountService.d.ts +13 -9
  317. package/dist/service/curd/CurdMixByAccountService.js +151 -89
  318. package/dist/service/curd/CurdMixByDictService.d.ts +12 -13
  319. package/dist/service/curd/CurdMixByDictService.js +114 -113
  320. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +30 -22
  321. package/dist/service/curd/CurdMixByLinkToCustomService.js +202 -154
  322. package/dist/service/curd/CurdMixBySysConfigService.d.ts +13 -9
  323. package/dist/service/curd/CurdMixBySysConfigService.js +116 -80
  324. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +11 -10
  325. package/dist/service/curd/CurdMixByWorkbenchService.js +80 -78
  326. package/dist/service/curd/CurdMixService.d.ts +28 -17
  327. package/dist/service/curd/CurdMixService.js +100 -76
  328. package/dist/service/curd/CurdMixUtils.d.ts +57 -28
  329. package/dist/service/curd/CurdMixUtils.js +331 -201
  330. package/dist/service/curd/CurdProService.d.ts +32 -39
  331. package/dist/service/curd/CurdProService.js +212 -322
  332. package/dist/service/curd/fixCfgModel.d.ts +3 -0
  333. package/dist/service/curd/fixCfgModel.js +104 -0
  334. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  335. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  336. package/dist/service/proxyapi/ProxyApiService.d.ts +61 -60
  337. package/dist/service/proxyapi/ProxyApiService.js +294 -260
  338. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  339. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  340. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  341. package/dist/service/proxyapi/RouteHandler.js +9 -9
  342. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  343. package/dist/service/proxyapi/RouteTrie.js +63 -63
  344. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  345. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  346. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  347. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  348. package/dist/views/404_app.html +31 -31
  349. package/dist/views/404_workbench.html +34 -34
  350. package/index.d.ts +10 -10
  351. package/package.json +87 -75
  352. package/src/config/config.default.ts +191 -203
  353. package/src/config/seed/aeskey.txt +1 -1
  354. package/src/config/utils.ts +22 -23
  355. package/src/configuration.ts +109 -83
  356. package/src/controller/base/BaseApiController.ts +209 -145
  357. package/src/controller/gateway/AnyApiGatewayController.ts +33 -33
  358. package/src/controller/gateway/AsyncTaskController.ts +157 -0
  359. package/src/controller/gateway/CrudMtdGatewayController.ts +116 -107
  360. package/src/controller/gateway/CrudStdGatewayController.ts +113 -101
  361. package/src/controller/gateway/DocGatewayController.ts +173 -173
  362. package/src/controller/gateway/FileController.ts +123 -110
  363. package/src/controller/gateway/ProxyApiGatewayController.ts +47 -47
  364. package/src/controller/gateway/PublicApiController.ts +179 -145
  365. package/src/controller/gateway/StaticController.ts +296 -328
  366. package/src/controller/helpers.controller.ts +161 -161
  367. package/src/controller/home.controller.ts +66 -69
  368. package/src/controller/manage/AnyApiMangeApi.ts +66 -66
  369. package/src/controller/manage/AppLogMangeApi.ts +53 -53
  370. package/src/controller/manage/AppMangeApi.ts +66 -53
  371. package/src/controller/manage/AppPageMangeApi.ts +52 -52
  372. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -49
  373. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -49
  374. package/src/controller/manage/CrudStandardDesignApi.ts +406 -398
  375. package/src/controller/manage/DataDictManageApi.ts +78 -78
  376. package/src/controller/manage/DeployManageApi.ts +175 -182
  377. package/src/controller/manage/DocLibManageApi.ts +69 -69
  378. package/src/controller/manage/DocManageApi.ts +99 -99
  379. package/src/controller/manage/FileManageApi.ts +45 -45
  380. package/src/controller/manage/LowCodeTplManageApi.ts +52 -52
  381. package/src/controller/manage/MenuManageApi.ts +58 -63
  382. package/src/controller/manage/ProxyApiMangeApi.ts +52 -52
  383. package/src/controller/manage/SuperAdminManageApi.ts +139 -147
  384. package/src/controller/manage/SysConfigMangeApi.ts +103 -98
  385. package/src/controller/manage/SystemInfoManageApi.ts +53 -48
  386. package/src/controller/manage/UserAccountManageApi.ts +122 -88
  387. package/src/controller/manage/WorkbenchMangeApi.ts +72 -72
  388. package/src/controller/myinfo/AuthController.ts +108 -174
  389. package/src/controller/myinfo/MyInfoController.ts +32 -32
  390. package/src/controller/render/AppRenderController.ts +72 -79
  391. package/src/controller/test.controller.ts +37 -37
  392. package/src/filter/default.filter.ts +13 -13
  393. package/src/filter/notfound.filter.ts +10 -10
  394. package/src/index.ts +108 -99
  395. package/src/interface.ts +33 -31
  396. package/src/libs/crud-pro/CrudPro.ts +165 -158
  397. package/src/libs/crud-pro/defaultConfigs.ts +15 -13
  398. package/src/libs/crud-pro/exceptions.ts +126 -124
  399. package/src/libs/crud-pro/interfaces.ts +194 -183
  400. package/src/libs/crud-pro/models/ExecuteContext.ts +120 -111
  401. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +96 -86
  402. package/src/libs/crud-pro/models/FuncContext.ts +21 -21
  403. package/src/libs/crud-pro/models/RequestCfgModel.ts +141 -141
  404. package/src/libs/crud-pro/models/RequestModel.ts +141 -141
  405. package/src/libs/crud-pro/models/ResModel.ts +19 -0
  406. package/src/libs/crud-pro/models/ServiceHub.ts +32 -32
  407. package/src/libs/crud-pro/models/SqlCfgModel.ts +53 -52
  408. package/src/libs/crud-pro/models/SqlSegArg.ts +13 -13
  409. package/src/libs/crud-pro/models/Transaction.ts +81 -74
  410. package/src/libs/crud-pro/models/TransactionMySQL.ts +79 -79
  411. package/src/libs/crud-pro/models/TransactionPostgres.ts +91 -91
  412. package/src/libs/crud-pro/models/TransactionSqlServer.ts +102 -107
  413. package/src/libs/crud-pro/models/keys.ts +165 -159
  414. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +83 -75
  415. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +145 -128
  416. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +264 -279
  417. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +60 -60
  418. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +180 -180
  419. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +374 -373
  420. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +185 -202
  421. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +399 -397
  422. package/src/libs/crud-pro/services/CrudProServiceBase.ts +104 -98
  423. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -59
  424. package/src/libs/crud-pro/services/CurdProServiceHub.ts +92 -92
  425. package/src/libs/crud-pro/sql.txt +120 -120
  426. package/src/libs/crud-pro/utils/CompareUtils.ts +23 -23
  427. package/src/libs/crud-pro/utils/DatabaseName.ts +60 -40
  428. package/src/libs/crud-pro/utils/DateTimeUtils.ts +20 -20
  429. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +64 -64
  430. package/src/libs/crud-pro/utils/MessageParseUtils.ts +33 -33
  431. package/src/libs/crud-pro/utils/MixinUtils.ts +285 -285
  432. package/src/libs/crud-pro/utils/ModelUtils.ts +60 -55
  433. package/src/libs/crud-pro/utils/MultiKeyMap.ts +72 -72
  434. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +29 -29
  435. package/src/libs/crud-pro/utils/TypeUtils.ts +188 -188
  436. package/src/libs/crud-pro/utils/ValidateUtils.ts +165 -167
  437. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +20 -20
  438. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +22 -22
  439. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +22 -22
  440. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +39 -26
  441. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +24 -0
  442. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +13 -11
  443. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +14 -11
  444. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +127 -129
  445. package/src/libs/global-config/global-config.ts +108 -47
  446. package/src/libs/utils/AsymmetricCrypto.ts +310 -0
  447. package/src/libs/utils/base64.ts +40 -0
  448. package/src/libs/utils/common-dto.ts +52 -52
  449. package/src/libs/utils/crypto-utils.ts +50 -52
  450. package/src/libs/utils/errorToString.ts +61 -0
  451. package/src/libs/utils/fatcms-request.ts +103 -115
  452. package/src/libs/utils/format-url.ts +16 -0
  453. package/src/libs/utils/functions.ts +78 -67
  454. package/src/libs/utils/ordernum-utils.ts +14 -18
  455. package/src/libs/utils/parseConfig.ts +58 -62
  456. package/src/libs/utils/parseCreateSql.ts +91 -91
  457. package/src/libs/utils/render-utils.ts +216 -184
  458. package/src/middleware/forbidden.middleware.ts +52 -71
  459. package/src/middleware/global.middleware.ts +301 -278
  460. package/src/middleware/permission.middleware.ts +80 -81
  461. package/src/middleware/rediscache.middleware.ts +91 -0
  462. package/src/middleware/redislock.middleware.ts +83 -0
  463. package/src/middleware/tx.middleware.ts +30 -30
  464. package/src/models/AsyncTaskModel.ts +85 -0
  465. package/src/models/RedisKeys.ts +16 -0
  466. package/src/models/SystemEntities.ts +137 -115
  467. package/src/models/SystemPerm.ts +104 -105
  468. package/src/models/SystemTables.ts +26 -26
  469. package/src/models/WorkbenchInfoTools.ts +19 -0
  470. package/src/models/bizmodels.ts +163 -89
  471. package/src/models/contextLogger.ts +141 -132
  472. package/src/models/devops.ts +17 -17
  473. package/src/models/userSession.ts +221 -216
  474. package/src/schedule/anonymousContext.ts +75 -0
  475. package/src/schedule/index.ts +5 -73
  476. package/src/schedule/runSchedule.ts +74 -0
  477. package/src/schedule/scheduleNames.ts +15 -0
  478. package/src/service/AuthService.ts +299 -275
  479. package/src/service/EnumInfoService.ts +124 -134
  480. package/src/service/FileCenterService.ts +395 -400
  481. package/src/service/SysAppService.ts +88 -0
  482. package/src/service/SysConfigService.ts +51 -38
  483. package/src/service/UserAccountService.ts +107 -110
  484. package/src/service/UserSessionService.ts +163 -81
  485. package/src/service/VisitStatService.ts +166 -183
  486. package/src/service/WorkbenchService.ts +277 -165
  487. package/src/service/anyapi/AnyApiSandboxService.ts +121 -121
  488. package/src/service/anyapi/AnyApiService.ts +186 -189
  489. package/src/service/asyncTask/AsyncTaskRunnerService.ts +319 -0
  490. package/src/service/asyncTask/AsyncTaskService.ts +21 -0
  491. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  492. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
  493. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +159 -0
  494. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +158 -0
  495. package/src/service/base/ApiBaseService.ts +42 -42
  496. package/src/service/base/ApiRateLimiter.ts +59 -59
  497. package/src/service/base/BaseService.ts +95 -74
  498. package/src/service/base/cache/CacheServiceFactory.ts +86 -0
  499. package/src/service/base/cache/CtxCache.ts +45 -0
  500. package/src/service/base/cache/DiskCache.ts +82 -0
  501. package/src/service/base/cache/MemoryCache.ts +68 -0
  502. package/src/service/base/cache/NoneCache.ts +24 -0
  503. package/src/service/base/cache/RedisCache.ts +41 -0
  504. package/src/service/crudstd/CrudStdActionService.ts +27 -27
  505. package/src/service/crudstd/CrudStdConstant.ts +62 -62
  506. package/src/service/crudstd/CrudStdRelationService.ts +131 -78
  507. package/src/service/crudstd/CrudStdService.ts +458 -198
  508. package/src/service/curd/CrudProQuick.ts +189 -0
  509. package/src/service/curd/CurdMixByAccountService.ts +161 -88
  510. package/src/service/curd/CurdMixByDictService.ts +115 -119
  511. package/src/service/curd/CurdMixByLinkToCustomService.ts +221 -167
  512. package/src/service/curd/CurdMixBySysConfigService.ts +121 -83
  513. package/src/service/curd/CurdMixByWorkbenchService.ts +71 -72
  514. package/src/service/curd/CurdMixService.ts +97 -65
  515. package/src/service/curd/CurdMixUtils.ts +383 -248
  516. package/src/service/curd/CurdProService.ts +231 -379
  517. package/src/service/curd/fixCfgModel.ts +120 -0
  518. package/src/service/proxyapi/ProxyApiLoadService.ts +170 -173
  519. package/src/service/proxyapi/ProxyApiService.ts +298 -262
  520. package/src/service/proxyapi/ProxyApiUtils.ts +32 -32
  521. package/src/service/proxyapi/RouteHandler.ts +8 -8
  522. package/src/service/proxyapi/RouteTrie.ts +74 -74
  523. package/src/service/proxyapi/WeightedRandom.ts +37 -37
  524. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -44
  525. package/src/views/404_app.html +31 -31
  526. package/src/views/404_workbench.html +34 -34
  527. package/tsconfig.json +32 -0
  528. package/dist/service/base/RedisCacheService.d.ts +0 -13
  529. package/dist/service/base/RedisCacheService.js +0 -50
  530. package/src/service/base/RedisCacheService.ts +0 -38
@@ -1,379 +1,231 @@
1
- import * as _ from 'lodash';
2
- import {Config, Inject, Provide} from '@midwayjs/core';
3
- import {CrudPro} from '../../libs/crud-pro/CrudPro';
4
- import {Context} from '@midwayjs/koa';
5
- import {
6
- IConnectionPool,
7
- ICrudProCfg,
8
- IRequestCfgModel,
9
- IRequestModel,
10
- ISqlCfgModel
11
- } from '../../libs/crud-pro/interfaces';
12
- import {SqlCfgModel} from '../../libs/crud-pro/models/SqlCfgModel';
13
- import {getConnectionPool as getMySQLConnectionPool} from '../../libs/crud-pro/utils/pool/MySQLUtils';
14
- import {getConnectionPool as getPostgresConnectionPool} from '../../libs/crud-pro/utils/pool/PostgresUtils';
15
- import {getConnectionPool as getSqlServerConnectionPool} from '../../libs/crud-pro/utils/pool/SqlServerUtils';
16
- import {KeysOfSimpleSQL, SqlDbType} from '../../libs/crud-pro/models/keys';
17
- import {CommonException, Exceptions} from '../../libs/crud-pro/exceptions';
18
- import {UserSessionInfo} from '../../models/userSession';
19
- import {BaseExecuteContextFunc} from '../../libs/crud-pro/models/ExecuteContextFunc';
20
- import {ExecuteContext, IExecuteContextHandler} from '../../libs/crud-pro/models/ExecuteContext';
21
- import {RelatedType} from './CurdMixUtils';
22
- import {BaseService} from '../base/BaseService';
23
- import {
24
- CTX_VISITOR_ACCOUNT_TYPE,
25
- CTX_VISITOR_AVATAR,
26
- CTX_VISITOR_ID,
27
- CTX_VISITOR_NICKNAME,
28
- IRequestCfgModel2,
29
- IVisitorExt,
30
- } from '../../models/bizmodels';
31
- import {IWorkbenchEntity} from '../../models/SystemEntities';
32
-
33
- function toVisitor(ctx: Context): IVisitorExt {
34
- const workbenchInfo: IWorkbenchEntity = ctx.workbenchInfo;
35
- const userSession: UserSessionInfo = ctx.userSession;
36
- if (!userSession || !userSession.isLogin()) {
37
- return {
38
- isLogin: false,
39
- isSuperAdmin: false,
40
- accountId: '0',
41
- nickName: '匿名用户',
42
- avatar: '',
43
- accountType: '',
44
- roleCodes: [],
45
- functionCodes: [],
46
- workbenchCode: workbenchInfo?.workbench_code || '',
47
- };
48
- }
49
-
50
- const sessionInfo = userSession.getSessionInfo();
51
- return {
52
- isLogin: true,
53
- isSuperAdmin: userSession.isSuperAdmin(),
54
- accountId: sessionInfo.accountId,
55
- nickName: sessionInfo.nickName,
56
- avatar: sessionInfo.avatar,
57
- accountType: sessionInfo.accountType,
58
- roleCodes: sessionInfo.roleCodes || [],
59
- functionCodes: sessionInfo.functionCodes || [],
60
- workbenchCode: workbenchInfo?.workbench_code || '',
61
- };
62
- }
63
-
64
- class MyContextFunc extends BaseExecuteContextFunc {
65
- private readonly mysql2Config: any;
66
- private readonly postgres2Config: any;
67
- private readonly sqlserver2Config: any;
68
- private readonly responseCfgHandlers: Record<string, IExecuteContextHandler>;
69
-
70
- constructor(cfgMap: any, responseCfgHandlers: Record<string, IExecuteContextHandler>) {
71
- super();
72
- const {mysql2Config, postgres2Config, sqlserver2Config} = cfgMap;
73
- this.mysql2Config = mysql2Config;
74
- this.postgres2Config = postgres2Config;
75
- this.sqlserver2Config = sqlserver2Config;
76
- this.responseCfgHandlers = responseCfgHandlers;
77
- }
78
-
79
- async getConnectionPool(sqlCfgModel: SqlCfgModel): Promise<IConnectionPool> {
80
- if (!sqlCfgModel.sqlDatabase) {
81
- console.error('查询语句中未指定数据库', sqlCfgModel.executeSql);
82
- throw new CommonException(Exceptions.DB_QUERY_PARAM_EMPTY, '查询语句中未指定数据库');
83
- }
84
- const dataBaseName = sqlCfgModel.sqlDatabase;
85
- const sqlDdType = sqlCfgModel.sqlDdType;
86
-
87
- if (sqlDdType === SqlDbType.postgres) {
88
- const dbConfig = _.get(this.postgres2Config, dataBaseName);
89
- if (!dbConfig) {
90
- throw new CommonException(Exceptions.DB_NOT_FOUND, 'postgres配置中不存在此数据库:' + dataBaseName);
91
- }
92
- return getPostgresConnectionPool(dataBaseName, dbConfig);
93
- }
94
-
95
- if (sqlDdType === SqlDbType.sqlserver) {
96
- const dbConfig = _.get(this.sqlserver2Config, dataBaseName);
97
- if (!dbConfig) {
98
- throw new CommonException(Exceptions.DB_NOT_FOUND, 'sqlserver配置中不存在此数据库:' + dataBaseName);
99
- }
100
- return getSqlServerConnectionPool(dataBaseName, dbConfig);
101
- }
102
-
103
- const dbConfig = _.get(this.mysql2Config, dataBaseName);
104
- if (!dbConfig) {
105
- throw new CommonException(Exceptions.DB_NOT_FOUND, 'MySQL配置中不存在此数据库:' + dataBaseName);
106
- }
107
- return getMySQLConnectionPool(dataBaseName, dbConfig);
108
- }
109
-
110
-
111
- async afterExecuteSQLList(): Promise<any> {
112
- const exeCtx = this.getExecuteContext();
113
- const handlers = Object.values(this.responseCfgHandlers);
114
- for (let i = 0; i < handlers.length; i++) {
115
- const handler = handlers[i];
116
- await handler.handleExecuteContextPrepare(exeCtx);
117
- await handler.handleExecuteContext(exeCtx);
118
- }
119
- return null;
120
- }
121
- }
122
-
123
- export class DBUtils {
124
- private readonly sqlDatabase: string;
125
- private readonly sqlDdType: SqlDbType;
126
- private readonly curdProService: CurdProService;
127
-
128
- constructor(sqlDatabase: string, sqlDdType: SqlDbType, curdProService: CurdProService) {
129
- this.sqlDatabase = sqlDatabase;
130
- this.sqlDdType = sqlDdType;
131
- this.curdProService = curdProService;
132
- }
133
-
134
- public async getOne(reqJson: IRequestModel, sqlTable: string): Promise<any> {
135
- const cfgModel: IRequestCfgModel = {
136
- sqlTable,
137
- sqlSimpleName: KeysOfSimpleSQL.SIMPLE_QUERY_ONE,
138
- sqlDatabase: this.sqlDatabase,
139
- sqlDdType: this.sqlDdType,
140
- updateCfg: {},
141
- };
142
- const res = await this.curdProService.executeCrudByCfg(reqJson, cfgModel);
143
- return res.getOneObj();
144
- }
145
-
146
- public async getList(reqJson: IRequestModel, sqlTable: string): Promise<any[]> {
147
- const cfgModel: IRequestCfgModel = {
148
- sqlTable,
149
- sqlSimpleName: KeysOfSimpleSQL.SIMPLE_QUERY,
150
- sqlDatabase: this.sqlDatabase,
151
- sqlDdType: this.sqlDdType,
152
- updateCfg: {},
153
- };
154
- const res = await this.curdProService.executeCrudByCfg(reqJson, cfgModel);
155
- return res.getResRows();
156
- }
157
- }
158
-
159
- function isSimpleQuery(sqlSimpleName: KeysOfSimpleSQL): boolean {
160
- return sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY ||
161
- sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY_COUNT ||
162
- sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY_PAGE ||
163
- sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY_ONE
164
- }
165
-
166
- @Provide()
167
- export class CurdProService extends BaseService {
168
- @Inject()
169
- protected ctx: Context;
170
-
171
- @Config('mysql2')
172
- private mysql2Config: any;
173
-
174
- @Config('postgres2')
175
- private postgres2Config: any;
176
-
177
- @Config('sqlserver2')
178
- private sqlserver2Config: any;
179
-
180
- @Config('crudProCfg')
181
- private crudProCfg: ICrudProCfg;
182
-
183
- private responseCfgHandlers: Record<RelatedType, IExecuteContextHandler> = {} as any;
184
-
185
- public setResponseCfgHandlers(key: RelatedType, handler: IExecuteContextHandler) {
186
- this.responseCfgHandlers[key] = handler;
187
- }
188
-
189
- /**
190
- * Execute级别:每次调用都会产生新的
191
- * @private
192
- */
193
- private getCrudPro(): CrudPro {
194
- const visitor = toVisitor(this.ctx);
195
- this.logInfo('visitor', JSON.stringify(visitor));
196
-
197
- const crudPro = new CrudPro();
198
- crudPro.transaction = this.ctx.transaction;
199
- crudPro.logger = this.getContextLogger();
200
- crudPro.visitor = visitor;
201
- crudPro.contextCfg = this.crudProCfg;
202
-
203
- crudPro.contextFunc = new MyContextFunc({
204
- mysql2Config: this.mysql2Config,
205
- postgres2Config: this.postgres2Config,
206
- sqlserver2Config: this.sqlserver2Config
207
- }, this.responseCfgHandlers);
208
-
209
- return crudPro;
210
- }
211
-
212
- /**
213
- * 依赖缓存中与加载的配置
214
- * @param reqJson
215
- */
216
- async executeCrud(reqJson: IRequestModel) {
217
- if (!reqJson.method) {
218
- throw new Error('Method not implemented');
219
- }
220
- const curdPro = this.getCrudPro();
221
-
222
- // 开发环境不使用缓存
223
- const isEnableCache = !this.isEnableDebug();
224
-
225
- return curdPro.executeCrud(reqJson, isEnableCache);
226
- }
227
-
228
- // 直接执行一个SQL
229
- public async executeSQL(sqlCfgModel: ISqlCfgModel): Promise<any> {
230
- const curdPro = this.getCrudPro();
231
- return curdPro.executeSQL(sqlCfgModel);
232
- }
233
-
234
- // 直接执行一个请求
235
- async executeCrudByCfg(reqJson: IRequestModel, cfgModel: IRequestCfgModel2): Promise<ExecuteContext> {
236
- this.logInfo('executeCrudByCfg', cfgModel);
237
-
238
- if (!cfgModel.method) {
239
- const req = this.ctx.req;
240
- if (req) {
241
- cfgModel.method = `${req.method}:${req.url}`;
242
- } else {
243
- cfgModel.method = 'anonymous';
244
- }
245
- }
246
-
247
- if (!cfgModel.updateCfg) {
248
- cfgModel.updateCfg = {};
249
- }
250
-
251
- // 应用标准的updateCfg
252
- this.applyStandardUpdateCfg(cfgModel);
253
-
254
- const curdPro = this.getCrudPro();
255
- return await curdPro.executeCrudByCfg(reqJson, cfgModel);
256
- }
257
-
258
-
259
- private applyStandardUpdateCfg( cfgModel: IRequestCfgModel2 ){
260
-
261
- const sqlSimpleName = cfgModel.sqlSimpleName;
262
-
263
- const enableStandardUpdateCfg = cfgModel.enableStandardUpdateCfg; // 用于设置data字段
264
- const enableStandardUpdateCfgCondition = cfgModel.enableStandardUpdateCfgCondition; // 用于设置condition字段
265
-
266
- // 彻底关闭
267
- if (enableStandardUpdateCfg === false) {
268
- return ;
269
- }
270
-
271
- const getDataCfgArray = ()=>{
272
- // 明确有配置
273
- if (Array.isArray(enableStandardUpdateCfg)) {
274
- if (enableStandardUpdateCfg.includes('null')) {
275
- return [];
276
- }
277
- return enableStandardUpdateCfg;
278
- }
279
- // update 、insert 添加 by
280
- return ['by']; // 创建/修改语句默认添加by
281
- }
282
-
283
- const getConditionCfgArray = ()=>{
284
- // 明确有配置
285
- if (Array.isArray(enableStandardUpdateCfgCondition)) {
286
- if (enableStandardUpdateCfgCondition.includes('null')) {
287
- return [];
288
- }
289
- return enableStandardUpdateCfgCondition;
290
- }
291
- return [];
292
- }
293
-
294
-
295
- const dataCfgArray = getDataCfgArray();
296
- const conditionCfgArray = getConditionCfgArray();
297
-
298
- const mapping = {
299
-
300
- 'condition.created_by': {contextAsString: CTX_VISITOR_ID},
301
- 'condition.created_account_type': {contextAsString: CTX_VISITOR_ACCOUNT_TYPE},
302
-
303
- 'data.created_by': {contextAsString: CTX_VISITOR_ID},
304
- 'data.created_avatar': {contextAsString: CTX_VISITOR_AVATAR},
305
- 'data.created_nickname': {contextAsString: CTX_VISITOR_NICKNAME},
306
- 'data.created_account_type': {contextAsString: CTX_VISITOR_ACCOUNT_TYPE},
307
-
308
- 'data.modified_by': {contextAsString: CTX_VISITOR_ID},
309
- 'data.modified_avatar': {contextAsString: CTX_VISITOR_AVATAR},
310
- 'data.modified_nickname': {contextAsString: CTX_VISITOR_NICKNAME},
311
- 'data.modified_account_type': {contextAsString: CTX_VISITOR_ACCOUNT_TYPE},
312
- };
313
-
314
-
315
- const buildUpdateCfgBy = (cfgArray: string[], prefix: string): any => {
316
- const obj: any = {};
317
- if (Array.isArray(cfgArray)) {
318
- for (let i = 0; i < cfgArray.length; i++) {
319
- const suffix = cfgArray[i];
320
- if (suffix) {
321
- const key = `${prefix}_${suffix}`
322
- obj[key] = mapping[key]
323
- }
324
- }
325
- }
326
- return obj;
327
- }
328
-
329
- // 查询语句
330
- if (isSimpleQuery(sqlSimpleName) ) {
331
- const updateCfgObj = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 查询用户本人创建的
332
- Object.assign(cfgModel.updateCfg, updateCfgObj);
333
- }
334
-
335
- // 删除语句
336
- if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_DELETE) {
337
- const updateCfgObj = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 删除用户本人创建的
338
- Object.assign(cfgModel.updateCfg, updateCfgObj);
339
- }
340
-
341
- // 插入语句
342
- if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_INSERT) {
343
- const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray,'data.created')
344
- Object.assign(cfgModel.updateCfg, updateCfgObj1);
345
- }
346
-
347
- // 更新语句
348
- if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_UPDATE) {
349
- const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray,'data.modified')
350
- const updateCfgObj2 = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 更新用户本人创建的
351
- Object.assign(cfgModel.updateCfg, updateCfgObj1);
352
- Object.assign(cfgModel.updateCfg, updateCfgObj2);
353
- }
354
-
355
- // 插入或更新
356
- if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE ||
357
- sqlSimpleName === KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE) {
358
- const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray,'data.created')
359
- const updateCfgObj2 = buildUpdateCfgBy(dataCfgArray,'data.modified')
360
- const updateCfgObj3 = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 更新用户本人创建的
361
- Object.assign(cfgModel.updateCfg, updateCfgObj1);
362
- Object.assign(cfgModel.updateCfg, updateCfgObj2);
363
- Object.assign(cfgModel.updateCfg, updateCfgObj3);
364
- }
365
- }
366
-
367
-
368
-
369
-
370
- getBbUtil(database: string, sqlDdType: SqlDbType): DBUtils {
371
- return new DBUtils(database, sqlDdType, this);
372
- }
373
-
374
- public async getCachedCfgByMethod(method: string): Promise<IRequestCfgModel> {
375
- const curdPro = this.getCrudPro();
376
- const isEnableCache = !this.isEnableDebug(); // 开发环境不使用缓存
377
- return curdPro.getCachedCfgByMethod(method, isEnableCache);
378
- }
379
- }
1
+ import * as _ from 'lodash';
2
+ import { Config, Inject, Provide } from '@midwayjs/core';
3
+ import { CrudPro } from '@/libs/crud-pro/CrudPro';
4
+ import { Context } from '@midwayjs/koa';
5
+ import { IConnectionPool, ICrudProCfg, IRequestCfgModel, IRequestModel, ISqlCfgModel } from '@/libs/crud-pro/interfaces';
6
+ import { SqlCfgModel } from '@/libs/crud-pro/models/SqlCfgModel';
7
+ import { getConnectionPool as getMySQLConnectionPool } from '../../libs/crud-pro/utils/pool/MySQLUtils';
8
+ import { getConnectionPool as getPostgresConnectionPool } from '../../libs/crud-pro/utils/pool/PostgresUtils';
9
+ import { getConnectionPool as getSqlServerConnectionPool } from '../../libs/crud-pro/utils/pool/SqlServerUtils';
10
+ import { SqlDbType } from '@/libs/crud-pro/models/keys';
11
+ import { CommonException, Exceptions } from '@/libs/crud-pro/exceptions';
12
+ import { UserSessionInfo } from '@/models/userSession';
13
+ import { BaseExecuteContextFunc } from '@/libs/crud-pro/models/ExecuteContextFunc';
14
+ import { ExecuteContext, IExecuteContextHandler } from '@/libs/crud-pro/models/ExecuteContext';
15
+ import { RelatedType } from './CurdMixUtils';
16
+ import { BaseService } from '../base/BaseService';
17
+ import { IRequestCfgModel2, IVisitorExt } from '@/models/bizmodels';
18
+ import { IWorkbenchEntity } from '@/models/SystemEntities';
19
+ import { CrudProQuick } from '@/service/curd/CrudProQuick';
20
+ import { fixCfgModel } from './fixCfgModel';
21
+ import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
22
+
23
+ function toVisitor(ctx: Context): IVisitorExt {
24
+ const workbenchInfo: IWorkbenchEntity = ctx.workbenchInfo;
25
+ const userSession: UserSessionInfo = ctx.userSession;
26
+ if (!userSession || !userSession.isLogin()) {
27
+ return {
28
+ isLogin: false,
29
+ isSuperAdmin: false,
30
+ accountId: '0',
31
+ nickName: '匿名用户',
32
+ avatar: '',
33
+ accountType: '',
34
+ roleCodes: [],
35
+ functionCodes: [],
36
+ workbenchCode: workbenchInfo?.workbench_code || '',
37
+ bizExt: {},
38
+ };
39
+ }
40
+
41
+ const sessionInfo = userSession.getSessionInfo();
42
+ return {
43
+ isLogin: true,
44
+ isSuperAdmin: userSession.isSuperAdmin(),
45
+ accountId: sessionInfo.accountId,
46
+ nickName: sessionInfo.nickName,
47
+ avatar: sessionInfo.avatar,
48
+ accountType: sessionInfo.accountType,
49
+ roleCodes: sessionInfo.roleCodes || [],
50
+ functionCodes: sessionInfo.functionCodes || [],
51
+ workbenchCode: workbenchInfo?.workbench_code || '',
52
+ bizExt: sessionInfo.bizExt || {},
53
+ };
54
+ }
55
+
56
+ class MyContextFunc extends BaseExecuteContextFunc {
57
+ private readonly mysql2Config: any;
58
+ private readonly postgres2Config: any;
59
+ private readonly sqlserver2Config: any;
60
+ private readonly responseCfgHandlers: Record<string, IExecuteContextHandler>;
61
+
62
+ constructor(cfgMap: any, responseCfgHandlers: Record<string, IExecuteContextHandler>) {
63
+ super();
64
+ const { mysql2Config, postgres2Config, sqlserver2Config } = cfgMap;
65
+ this.mysql2Config = mysql2Config;
66
+ this.postgres2Config = postgres2Config;
67
+ this.sqlserver2Config = sqlserver2Config;
68
+ this.responseCfgHandlers = responseCfgHandlers;
69
+ }
70
+
71
+ async getConnectionPool(sqlCfgModel: SqlCfgModel): Promise<IConnectionPool> {
72
+ if (!sqlCfgModel.sqlDatabase) {
73
+ console.error('[MyContextFunc]查询语句中未指定数据库', sqlCfgModel.executeSql);
74
+ throw new CommonException(Exceptions.DB_QUERY_PARAM_EMPTY, '查询语句中未指定数据库');
75
+ }
76
+ const dataBaseName = sqlCfgModel.sqlDatabase;
77
+ const sqlDbType = sqlCfgModel.sqlDbType;
78
+
79
+ if (sqlDbType === SqlDbType.postgres) {
80
+ const dbConfig = _.get(this.postgres2Config, dataBaseName);
81
+ if (!dbConfig) {
82
+ console.error('[MyContextFunc]postgres配置中不存在此数据库', JSON.stringify(sqlCfgModel));
83
+ throw new CommonException(Exceptions.DB_NOT_FOUND, 'postgres配置中不存在此数据库:' + dataBaseName);
84
+ }
85
+ return getPostgresConnectionPool(dataBaseName, dbConfig);
86
+ }
87
+
88
+ if (sqlDbType === SqlDbType.sqlserver) {
89
+ const dbConfig = _.get(this.sqlserver2Config, dataBaseName);
90
+ if (!dbConfig) {
91
+ console.error('[MyContextFunc]sqlserver配置中不存在此数据库', JSON.stringify(sqlCfgModel));
92
+ throw new CommonException(Exceptions.DB_NOT_FOUND, 'sqlserver配置中不存在此数据库:' + dataBaseName);
93
+ }
94
+ return getSqlServerConnectionPool(dataBaseName, dbConfig);
95
+ }
96
+
97
+ const dbConfig = _.get(this.mysql2Config, dataBaseName);
98
+ if (!dbConfig) {
99
+ console.error('[MyContextFunc]MySQL配置中不存在此数据库', JSON.stringify(sqlCfgModel));
100
+ throw new CommonException(Exceptions.DB_NOT_FOUND, 'MySQL配置中不存在此数据库:' + dataBaseName);
101
+ }
102
+ return getMySQLConnectionPool(dataBaseName, dbConfig);
103
+ }
104
+
105
+ async afterExecuteSQLList(): Promise<any> {
106
+ const exeCtx = this.getExecuteContext();
107
+ const handlers = Object.values(this.responseCfgHandlers);
108
+ for (let i = 0; i < handlers.length; i++) {
109
+ const handler = handlers[i];
110
+ await handler.handleExecuteContextPrepare(exeCtx);
111
+ await handler.handleExecuteContext(exeCtx);
112
+ }
113
+ return null;
114
+ }
115
+
116
+ /**
117
+ * 在执行之前可以根据业务需要修改需要执行的内容
118
+ * @param reqJson
119
+ * @param cfgJson
120
+ */
121
+ async beforeExecuteSQLList(reqJson: IRequestModel, cfgJson: IRequestCfgModel): Promise<any> {
122
+ const { bizUpdateCfgModelForCrudPro } = GLOBAL_STATIC_CONFIG.getConfig();
123
+ if (typeof bizUpdateCfgModelForCrudPro === 'function') {
124
+ await bizUpdateCfgModelForCrudPro(reqJson, cfgJson);
125
+ }
126
+ return Promise.resolve();
127
+ }
128
+ }
129
+
130
+ @Provide()
131
+ export class CurdProService extends BaseService {
132
+ @Inject()
133
+ protected ctx: Context;
134
+
135
+ @Config('mysql2')
136
+ private mysql2Config: any;
137
+
138
+ @Config('postgres2')
139
+ private postgres2Config: any;
140
+
141
+ @Config('sqlserver2')
142
+ private sqlserver2Config: any;
143
+
144
+ @Config('crudProCfg')
145
+ private crudProCfg: ICrudProCfg;
146
+
147
+ private responseCfgHandlers: Record<RelatedType, IExecuteContextHandler> = {} as any;
148
+
149
+ public setResponseCfgHandlers(key: RelatedType, handler: IExecuteContextHandler) {
150
+ this.responseCfgHandlers[key] = handler;
151
+ }
152
+
153
+ public getResponseCfgHandlers(): Record<RelatedType, IExecuteContextHandler> {
154
+ return this.responseCfgHandlers;
155
+ }
156
+
157
+ /**
158
+ * Execute级别:每次调用都会产生新的
159
+ * @private
160
+ */
161
+ private getCrudPro(): CrudPro {
162
+ const visitor = toVisitor(this.ctx);
163
+ this.logInfo('visitor', JSON.stringify(visitor));
164
+
165
+ const crudPro = new CrudPro();
166
+ crudPro.transaction = this.ctx.transaction;
167
+ crudPro.logger = this.getContextLogger() as any;
168
+ crudPro.visitor = visitor;
169
+
170
+ const crudProCfg: ICrudProCfg = this.crudProCfg || {};
171
+ const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
172
+ crudProCfg.sysDatabaseName = SystemDbName;
173
+ crudProCfg.sysDatabaseDbType = SystemDbType;
174
+
175
+ crudPro.contextCfg = crudProCfg;
176
+
177
+ crudPro.contextFunc = new MyContextFunc(
178
+ {
179
+ mysql2Config: this.mysql2Config,
180
+ postgres2Config: this.postgres2Config,
181
+ sqlserver2Config: this.sqlserver2Config,
182
+ },
183
+ this.responseCfgHandlers
184
+ );
185
+
186
+ return crudPro;
187
+ }
188
+
189
+ /**
190
+ * 依赖缓存中与加载的配置
191
+ * @param reqJson
192
+ */
193
+ async executeCrud(reqJson: IRequestModel): Promise<ExecuteContext> {
194
+ if (!reqJson.method) {
195
+ throw new Error('Method not implemented');
196
+ }
197
+ const curdPro = this.getCrudPro();
198
+
199
+ // 开发环境不使用缓存
200
+ const isEnableCache = !this.isEnableDebug();
201
+
202
+ return curdPro.executeCrud(reqJson, isEnableCache);
203
+ }
204
+
205
+ // 直接执行一个SQL
206
+ public async executeSQL(sqlCfgModel: ISqlCfgModel): Promise<any> {
207
+ const curdPro = this.getCrudPro();
208
+ return curdPro.executeSQL(sqlCfgModel);
209
+ }
210
+
211
+ // 直接执行一个请求
212
+ public async executeCrudByCfg(reqJson: IRequestModel, cfgModel: IRequestCfgModel2): Promise<ExecuteContext> {
213
+ this.logInfo('executeCrudByCfg', cfgModel);
214
+ const curdPro = this.getCrudPro();
215
+
216
+ // 应用标准的updateCfg。
217
+ fixCfgModel(cfgModel);
218
+ return await curdPro.executeCrudByCfg(reqJson, cfgModel);
219
+ }
220
+
221
+ public getBbUtil(sqlDatabase: string, sqlDbType: SqlDbType, sqlTable?: string): CrudProQuick {
222
+ const curdPro = this.getCrudPro();
223
+ return new CrudProQuick(curdPro, sqlDatabase, sqlDbType, sqlTable);
224
+ }
225
+
226
+ public async getCachedCfgByMethod(method: string): Promise<IRequestCfgModel> {
227
+ const curdPro = this.getCrudPro();
228
+ const isEnableCache = !this.isEnableDebug(); // 开发环境不使用缓存
229
+ return curdPro.getCachedCfgByMethod(method, isEnableCache);
230
+ }
231
+ }