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

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 +32 -25
  24. package/dist/controller/gateway/FileController.js +160 -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 +50 -42
  100. package/dist/libs/crud-pro/models/ExecuteContext.js +87 -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 +20 -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 +138 -69
  239. package/dist/models/bizmodels.js +61 -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 +64 -43
  259. package/dist/service/FileCenterService.js +422 -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 +138 -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 +129 -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 +24 -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 +170 -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 +483 -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,279 +1,264 @@
1
- import * as _ from 'lodash';
2
- import {PoolClient} from 'pg'
3
- import {CrudProServiceBase} from './CrudProServiceBase';
4
- import {SqlCfgModel} from '../models/SqlCfgModel';
5
- import {KeyOfCrudTypes, KeysOfCustomSQL, KeysOfSqlResPicker, SqlDbType} from '../models/keys';
6
- import {CommonException, Exceptions} from '../exceptions';
7
- import {pickAndConvertPgRows} from '../utils/sqlConvert/convertPgType';
8
- import {replaceQuestionMarks} from "../utils/sqlConvert/convertPgSql";
9
- import {replaceQuestionMarksForMssql} from "../utils/sqlConvert/convertMsSql";
10
- import {ModelUtils} from '../utils/ModelUtils';
11
- import {MixinUtils} from '../utils/MixinUtils';
12
- import {FuncContext} from '../models/FuncContext';
13
- import {ExecuteContext} from "../models/ExecuteContext";
14
-
15
- const { checkFuncCfgValid } = ModelUtils;
16
- const { isEmpty } = MixinUtils;
17
-
18
- class CrudProExecuteSqlService extends CrudProServiceBase {
19
- async executeSqlCfgModels(): Promise<void> {
20
- const exeCtx = this.getExecuteContext();
21
- const sqlCfgModels = exeCtx.getSqlCfgModels();
22
- for (let i = 0; i < sqlCfgModels.length; i++) {
23
- const sqlCfgModel = sqlCfgModels[i];
24
- const checkResult = this.executeSqlCfgModelPreCheck(sqlCfgModel);
25
- if (checkResult) {
26
- await this.executeSqlCfgModel(sqlCfgModel);
27
- }
28
- }
29
- }
30
-
31
- private async executeSqlCfgModel(sqlCfgModel: SqlCfgModel) {
32
- this.logger.info('executeSqlCfgModel1', sqlCfgModel.executeSql, sqlCfgModel.executeSqlArgs);
33
-
34
- const exeCtx = this.getExecuteContext();
35
- const connection = await this.getTxConnectionBySqlCfg(sqlCfgModel);
36
- const executeSqlArgs = this.handleExecuteSqlArgsByResModel(exeCtx, sqlCfgModel.executeSqlArgs || [])
37
-
38
-
39
- let sqlRes: any;
40
- let queryRes : any;
41
-
42
- if (sqlCfgModel.sqlDdType === SqlDbType.postgres) { // import { PoolClient } from 'pg';
43
-
44
- const pgClient: PoolClient = connection as any;
45
- const pgSql = replaceQuestionMarks(sqlCfgModel.executeSql);
46
-
47
- this.logger.info('executeSqlCfgModel_postgres', pgSql, executeSqlArgs, sqlCfgModel.resPicker);
48
-
49
-
50
- queryRes = await pgClient.query({
51
- text: pgSql,
52
- values: executeSqlArgs || []
53
- });
54
- sqlRes = pickAndConvertPgRows(queryRes)
55
-
56
- }
57
-
58
- else if (sqlCfgModel.sqlDdType === SqlDbType.sqlserver) {
59
-
60
- const mssql = replaceQuestionMarksForMssql(sqlCfgModel.executeSql);
61
-
62
- this.logger.info('executeSqlCfgModel_sqlserver', mssql, executeSqlArgs, sqlCfgModel.resPicker);
63
- // SQLServer
64
- queryRes = await connection.query(mssql, executeSqlArgs);
65
- sqlRes = _.get(queryRes,'recordsets[0]') || []
66
- }
67
-
68
- else {
69
-
70
- this.logger.info('executeSqlCfgModel_mysql', sqlCfgModel.executeSql, executeSqlArgs, sqlCfgModel.resPicker);
71
-
72
-
73
- // MYSQL
74
- queryRes = await connection.query(sqlCfgModel.executeSql, executeSqlArgs);
75
- sqlRes = queryRes[0]
76
- }
77
-
78
- const resObject = this.toQueryResByResPicker(sqlRes, queryRes, sqlCfgModel);
79
- exeCtx.setResModelItem(sqlCfgModel.resName, resObject);
80
- }
81
-
82
-
83
- private handleExecuteSqlArgsByResModel(exeCtx: ExecuteContext, executeSqlArgs: any[]): any[] {
84
- return executeSqlArgs.map((arg)=> {
85
- if (arg && typeof arg === 'object' && typeof arg.___GENERATE_GET_RES_ATTR___ === 'string' ) {
86
- const word: string = arg.___GENERATE_GET_RES_ATTR___;
87
- if (word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER)) {
88
- const resName = MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER)
89
- this.logger.info('handleExecuteSqlArgsByResModel resName', resName);
90
- this.logger.info('handleExecuteSqlArgsByResModel getResModel', exeCtx.getResModel());
91
- return Number(exeCtx.getResModelItemLodash(resName) || 0);
92
- }
93
- if (word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_STRING)) {
94
- const resName = MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_PICK_RES_AS_STRING)
95
- return String(exeCtx.getResModelItemLodash(resName) || "");
96
- }
97
- }
98
- return arg;
99
- })
100
- }
101
-
102
-
103
- private executeSqlCfgModelPreCheck(sqlCfgModel: SqlCfgModel): boolean {
104
- const crudType = sqlCfgModel.getCrudType();
105
-
106
- if (KeyOfCrudTypes.EMPTY_SQL === crudType) {
107
- // 允许空SQL,没有需要执行的正常。
108
- return false;
109
- }
110
-
111
- if (KeyOfCrudTypes.NOT_CRUD === crudType) {
112
- // 只支持增删改查,其他语句不支持。
113
- throw new CommonException(Exceptions.CFG_NOT_SUPPORT_THE_SQL, sqlCfgModel.executeSql);
114
- }
115
-
116
- // 此SQL不需要执行
117
- if (!this.isNeedExecute(sqlCfgModel)) {
118
- return false;
119
- }
120
-
121
- // 执行之前,根据配置校验一下此SQL是否可以执行
122
- this.assertByValidate(sqlCfgModel);
123
-
124
- return true;
125
- }
126
-
127
- private assertByValidate(sqlCfgModel: SqlCfgModel) {
128
- const exeCtx = this.getExecuteContext();
129
- const funcCfg = sqlCfgModel.validate;
130
- if (!funcCfg) {
131
- return; // 没有配置。
132
- }
133
-
134
- if (!checkFuncCfgValid(funcCfg)) {
135
- throw new CommonException(Exceptions.CFG_SQL_CFG_EXECUTE_VALIDATE_EMPTY, {
136
- funcCfg: funcCfg,
137
- originSql: sqlCfgModel.originSql,
138
- });
139
- }
140
-
141
- const errMsg = funcCfg.message || '执行前校验失败';
142
-
143
- let result;
144
- try {
145
- const exeFunCtx = new FuncContext();
146
-
147
- exeFunCtx.currentValue = null;
148
- exeFunCtx.reqModel = exeCtx.getReqModel();
149
- exeFunCtx.resModel = exeCtx.getResModel();
150
-
151
- result = this.serviceHub.executeFuncCfg(funcCfg, exeFunCtx); // 可以抛出异常
152
- } catch (e) {
153
- this.logger.debug('assertByValidate', e);
154
- throw new CommonException(Exceptions.RUN_EXECUTE_VALIDATE, {
155
- funcCfg: funcCfg,
156
- originSql: sqlCfgModel.originSql,
157
- error: '' + e,
158
- });
159
- }
160
-
161
- if (!(typeof result === 'boolean')) {
162
- // 自定义的校验函数,必须返回boolean类型的树枝
163
- throw new CommonException(Exceptions.CFG_IS_NEED_EXECUTE_FUNC_MUST_RETURN_BOOL, {
164
- funcCfg: funcCfg,
165
- originSql: sqlCfgModel.originSql,
166
- });
167
- }
168
-
169
- if (result === false) {
170
- throw new CommonException(Exceptions.RUN_EXECUTE_VALIDATE, errMsg);
171
- }
172
- }
173
-
174
- /**
175
- * 判断此SQL是否需要执行
176
- * @param sqlCfgModel
177
- * @param exeCtx
178
- * @private
179
- */
180
- private isNeedExecute(sqlCfgModel: SqlCfgModel) {
181
- const exeCtx = this.getExecuteContext();
182
- const funcCfg = sqlCfgModel.executeWhen;
183
- if (!funcCfg || Object.keys(funcCfg).length === 0) {
184
- return true; // 没有配置。默认,需要执行。
185
- }
186
-
187
- if (!checkFuncCfgValid(funcCfg)) {
188
- throw new CommonException(Exceptions.CFG_CHECK_EXECUTE_WHEN_EMPTY, {
189
- funcCfg: funcCfg,
190
- originSql: sqlCfgModel.originSql,
191
- });
192
- }
193
-
194
- let result;
195
-
196
- try {
197
- const exeFunCtx = new FuncContext();
198
-
199
- exeFunCtx.currentValue = null;
200
- exeFunCtx.reqModel = exeCtx.getReqModel();
201
- exeFunCtx.resModel = exeCtx.getResModel();
202
-
203
- result = this.serviceHub.executeFuncCfg(funcCfg, exeFunCtx);
204
- } catch (e) {
205
- this.logger.debug('isNeedExecute', e);
206
- throw new CommonException(Exceptions.RUN_IS_NEED_EXECUTE_ERR, {
207
- funcCfg: funcCfg,
208
- originSql: sqlCfgModel.originSql,
209
- error: '' + e,
210
- });
211
- }
212
-
213
- if (!(typeof result === 'boolean')) {
214
- // 自定义的校验函数,必须返回boolean类型的树枝
215
- throw new CommonException(Exceptions.CFG_IS_NEED_EXECUTE_FUNC_MUST_RETURN_BOOL, {
216
- funcCfg: funcCfg,
217
- originSql: sqlCfgModel.originSql,
218
- });
219
- }
220
-
221
- return result === true;
222
- }
223
-
224
- private toQueryResByResPicker(sqlRes: any, queryRes: any, sqlCfgModel: SqlCfgModel) {
225
- const resPicker = sqlCfgModel.resPicker;
226
-
227
- // 返回第一行
228
- if (KeysOfSqlResPicker.RESULT_FIRST_ROW === resPicker) {
229
- const rows = sqlRes as any[];
230
- if (rows && rows.length > 0) {
231
- return rows[0];
232
- }
233
- return null;
234
- }
235
-
236
- // $ResultSet[0].total_count , 只取第一行的的total_count
237
- if (KeysOfSqlResPicker.RESULT_TOTAL_COUNT === resPicker) {
238
- const rows = sqlRes as any[];
239
- if (isEmpty(rows)) {
240
- return 0;
241
- }
242
- const map0 = rows[0];
243
- return Number(map0['total_count'] || 0);
244
- }
245
-
246
- // 增删改res的内容是修改结果:包括: insert\delete\update
247
- if (KeysOfSqlResPicker.UPDATE_RESULT === resPicker) {
248
- if (sqlCfgModel.sqlDdType === SqlDbType.postgres) {
249
- return {
250
- insertId: _.get(queryRes,'rows[0].id'),
251
- affectedRows: _.get(queryRes,'rowCount')
252
- }
253
- }
254
-
255
- if (sqlCfgModel.sqlDdType === SqlDbType.sqlserver) {
256
- return {
257
- insertId: _.get(queryRes,'recordset[0].id'),
258
- affectedRows: _.get(queryRes,'rowsAffected[0]')
259
- }
260
- }
261
-
262
- return sqlRes;
263
- }
264
-
265
- //其他配置:形如: sqlRes[0].total_count
266
- if (typeof resPicker === 'string') {
267
- if (resPicker.startsWith('sqlRes')){
268
- return _.get({ sqlRes }, resPicker);
269
- } else {
270
- throw new CommonException(Exceptions.RUN_EXECUTE_VALIDATE, 'resPicker必须是以sqlRes开头')
271
- }
272
- }
273
-
274
- return sqlRes;
275
- }
276
-
277
- }
278
-
279
- export { CrudProExecuteSqlService };
1
+ import * as _ from 'lodash';
2
+ import { PoolClient } from 'pg';
3
+ import { CrudProServiceBase } from './CrudProServiceBase';
4
+ import { SqlCfgModel } from '../models/SqlCfgModel';
5
+ import { KeyOfCrudTypes, KeysOfCustomSQL, KeysOfSqlResPicker, SqlDbType } from '../models/keys';
6
+ import { CommonException, Exceptions } from '../exceptions';
7
+ import { pickAndConvertRowsByMix } from '../utils/sqlConvert/convertMix';
8
+ import { replaceQuestionMarks } from '../utils/sqlConvert/convertPgSql';
9
+ import { replaceQuestionMarksForMssql } from '../utils/sqlConvert/convertMsSql';
10
+ import { ModelUtils } from '../utils/ModelUtils';
11
+ import { MixinUtils } from '../utils/MixinUtils';
12
+ import { FuncContext } from '../models/FuncContext';
13
+ import { ExecuteContext } from '../models/ExecuteContext';
14
+
15
+ const { checkFuncCfgValid } = ModelUtils;
16
+ const { isEmpty } = MixinUtils;
17
+
18
+ class CrudProExecuteSqlService extends CrudProServiceBase {
19
+ async executeSqlCfgModels(): Promise<void> {
20
+ const exeCtx = this.getExecuteContext();
21
+ const sqlCfgModels = exeCtx.getSqlCfgModels();
22
+ for (let i = 0; i < sqlCfgModels.length; i++) {
23
+ const sqlCfgModel = sqlCfgModels[i];
24
+ const checkResult = this.executeSqlCfgModelPreCheck(sqlCfgModel);
25
+ if (checkResult) {
26
+ await this.executeSqlCfgModel(sqlCfgModel);
27
+ }
28
+ }
29
+ }
30
+
31
+ private async executeSqlCfgModel(sqlCfgModel: SqlCfgModel) {
32
+ this.logger.info('[CrudProExecuteSqlService] executeSqlCfgModel_before', sqlCfgModel.executeSql, sqlCfgModel.executeSqlArgs);
33
+
34
+ const exeCtx = this.getExecuteContext();
35
+ const connection = await this.getTxConnectionBySqlCfg(sqlCfgModel);
36
+ const executeSqlArgs = this.handleExecuteSqlArgsByResModel(exeCtx, sqlCfgModel.executeSqlArgs || []);
37
+
38
+ let queryRes: any;
39
+
40
+ if (sqlCfgModel.sqlDbType === SqlDbType.postgres) {
41
+ // import { PoolClient } from 'pg';
42
+
43
+ const pgClient: PoolClient = connection as any;
44
+ const pgSql = replaceQuestionMarks(sqlCfgModel.executeSql, sqlCfgModel.isNativeSQL);
45
+ queryRes = await pgClient.query({
46
+ text: pgSql,
47
+ values: executeSqlArgs || [],
48
+ });
49
+
50
+ this.logger.debug('[CrudProExecuteSqlService] executeSqlCfgModel_postgres', pgSql, executeSqlArgs, sqlCfgModel.resPicker);
51
+
52
+ } else if (sqlCfgModel.sqlDbType === SqlDbType.sqlserver) {
53
+ // SQLServer
54
+
55
+ const mssql = replaceQuestionMarksForMssql(sqlCfgModel.executeSql, sqlCfgModel.isNativeSQL);
56
+ queryRes = await connection.query(mssql, executeSqlArgs);
57
+ this.logger.debug('[CrudProExecuteSqlService] executeSqlCfgModel_sqlserver', mssql, executeSqlArgs, sqlCfgModel.resPicker);
58
+
59
+ } else {
60
+ // MYSQL
61
+ queryRes = await connection.query(sqlCfgModel.executeSql, executeSqlArgs);
62
+ this.logger.debug('[CrudProExecuteSqlService] executeSqlCfgModel_mysql', sqlCfgModel.executeSql, executeSqlArgs, sqlCfgModel.resPicker);
63
+ }
64
+
65
+ const sqlRes = pickAndConvertRowsByMix(queryRes, sqlCfgModel.sqlDbType);
66
+ const resObject = this.toQueryResByResPicker(sqlRes, queryRes, sqlCfgModel);
67
+ exeCtx.setResModelItem(sqlCfgModel.resName, resObject);
68
+ }
69
+
70
+ private handleExecuteSqlArgsByResModel(exeCtx: ExecuteContext, executeSqlArgs: any[]): any[] {
71
+ return executeSqlArgs.map(arg => {
72
+ if (arg && typeof arg === 'object' && typeof arg.___GENERATE_GET_RES_ATTR___ === 'string') {
73
+ const word: string = arg.___GENERATE_GET_RES_ATTR___;
74
+ if (word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER)) {
75
+ const resName = MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER);
76
+ this.logger.info('handleExecuteSqlArgsByResModel resName', resName);
77
+ this.logger.debug('handleExecuteSqlArgsByResModel getResModel', exeCtx.getResModel());
78
+ return Number(exeCtx.getResModelItemLodash(resName) || 0);
79
+ }
80
+ if (word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_STRING)) {
81
+ const resName = MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_PICK_RES_AS_STRING);
82
+ return String(exeCtx.getResModelItemLodash(resName) || '');
83
+ }
84
+ }
85
+ return arg;
86
+ });
87
+ }
88
+
89
+ private executeSqlCfgModelPreCheck(sqlCfgModel: SqlCfgModel): boolean {
90
+ const crudType = sqlCfgModel.getCrudType();
91
+
92
+ if (KeyOfCrudTypes.EMPTY_SQL === crudType) {
93
+ // 允许空SQL,没有需要执行的正常。
94
+ return false;
95
+ }
96
+
97
+ if (KeyOfCrudTypes.NOT_CRUD === crudType) {
98
+ // 只支持增删改查,其他语句不支持。
99
+ throw new CommonException(Exceptions.CFG_NOT_SUPPORT_THE_SQL, sqlCfgModel.executeSql);
100
+ }
101
+
102
+ // 此SQL不需要执行
103
+ if (!this.isNeedExecute(sqlCfgModel)) {
104
+ return false;
105
+ }
106
+
107
+ // 执行之前,根据配置校验一下此SQL是否可以执行
108
+ this.assertByValidate(sqlCfgModel);
109
+
110
+ return true;
111
+ }
112
+
113
+ private assertByValidate(sqlCfgModel: SqlCfgModel) {
114
+ const exeCtx = this.getExecuteContext();
115
+ const funcCfg = sqlCfgModel.validate;
116
+ if (!funcCfg) {
117
+ return; // 没有配置。
118
+ }
119
+
120
+ if (!checkFuncCfgValid(funcCfg)) {
121
+ throw new CommonException(Exceptions.CFG_SQL_CFG_EXECUTE_VALIDATE_EMPTY, {
122
+ funcCfg: funcCfg,
123
+ originSql: sqlCfgModel.originSql,
124
+ });
125
+ }
126
+
127
+ const errMsg = funcCfg.message || '执行前校验失败';
128
+
129
+ let result;
130
+ try {
131
+ const exeFunCtx = new FuncContext();
132
+
133
+ exeFunCtx.currentValue = null;
134
+ exeFunCtx.reqModel = exeCtx.getReqModel();
135
+ exeFunCtx.resModel = exeCtx.getResModel();
136
+
137
+ result = this.serviceHub.executeFuncCfg(funcCfg, exeFunCtx); // 可以抛出异常
138
+ } catch (e) {
139
+ this.logger.debug('assertByValidate', e);
140
+ throw new CommonException(Exceptions.RUN_EXECUTE_VALIDATE, {
141
+ funcCfg: funcCfg,
142
+ originSql: sqlCfgModel.originSql,
143
+ error: '' + e,
144
+ });
145
+ }
146
+
147
+ if (!(typeof result === 'boolean')) {
148
+ // 自定义的校验函数,必须返回boolean类型的树枝
149
+ throw new CommonException(Exceptions.CFG_IS_NEED_EXECUTE_FUNC_MUST_RETURN_BOOL, {
150
+ funcCfg: funcCfg,
151
+ originSql: sqlCfgModel.originSql,
152
+ });
153
+ }
154
+
155
+ if (result === false) {
156
+ throw new CommonException(Exceptions.RUN_EXECUTE_VALIDATE, errMsg);
157
+ }
158
+ }
159
+
160
+ /**
161
+ * 判断此SQL是否需要执行
162
+ * @param sqlCfgModel
163
+ * @param exeCtx
164
+ * @private
165
+ */
166
+ private isNeedExecute(sqlCfgModel: SqlCfgModel) {
167
+ const exeCtx = this.getExecuteContext();
168
+ const funcCfg = sqlCfgModel.executeWhen;
169
+ if (!funcCfg || Object.keys(funcCfg).length === 0) {
170
+ return true; // 没有配置。默认,需要执行。
171
+ }
172
+
173
+ if (!checkFuncCfgValid(funcCfg)) {
174
+ throw new CommonException(Exceptions.CFG_CHECK_EXECUTE_WHEN_EMPTY, {
175
+ funcCfg: funcCfg,
176
+ originSql: sqlCfgModel.originSql,
177
+ });
178
+ }
179
+
180
+ let result;
181
+
182
+ try {
183
+ const exeFunCtx = new FuncContext();
184
+
185
+ exeFunCtx.currentValue = null;
186
+ exeFunCtx.reqModel = exeCtx.getReqModel();
187
+ exeFunCtx.resModel = exeCtx.getResModel();
188
+
189
+ result = this.serviceHub.executeFuncCfg(funcCfg, exeFunCtx);
190
+ } catch (e) {
191
+ this.logger.debug('isNeedExecute', e);
192
+ throw new CommonException(Exceptions.RUN_IS_NEED_EXECUTE_ERR, {
193
+ funcCfg: funcCfg,
194
+ originSql: sqlCfgModel.originSql,
195
+ error: '' + e,
196
+ });
197
+ }
198
+
199
+ if (!(typeof result === 'boolean')) {
200
+ // 自定义的校验函数,必须返回boolean类型的树枝
201
+ throw new CommonException(Exceptions.CFG_IS_NEED_EXECUTE_FUNC_MUST_RETURN_BOOL, {
202
+ funcCfg: funcCfg,
203
+ originSql: sqlCfgModel.originSql,
204
+ });
205
+ }
206
+
207
+ return result === true;
208
+ }
209
+
210
+ private toQueryResByResPicker(sqlRes: any, queryRes: any, sqlCfgModel: SqlCfgModel) {
211
+ const resPicker = sqlCfgModel.resPicker;
212
+
213
+ // 返回第一行
214
+ if (KeysOfSqlResPicker.RESULT_FIRST_ROW === resPicker) {
215
+ const rows = sqlRes as any[];
216
+ if (rows && rows.length > 0) {
217
+ return rows[0];
218
+ }
219
+ return null;
220
+ }
221
+
222
+ // $ResultSet[0].total_count , 只取第一行的的total_count
223
+ if (KeysOfSqlResPicker.RESULT_TOTAL_COUNT === resPicker) {
224
+ const rows = sqlRes as any[];
225
+ if (isEmpty(rows)) {
226
+ return 0;
227
+ }
228
+ const map0 = rows[0];
229
+ return Number(map0['total_count'] || 0);
230
+ }
231
+
232
+ // 增删改res的内容是修改结果:包括: insert\delete\update
233
+ if (KeysOfSqlResPicker.UPDATE_RESULT === resPicker) {
234
+ if (sqlCfgModel.sqlDbType === SqlDbType.postgres) {
235
+ return {
236
+ insertId: _.get(queryRes, 'rows[0].id'),
237
+ affectedRows: _.get(queryRes, 'rowCount'),
238
+ };
239
+ }
240
+
241
+ if (sqlCfgModel.sqlDbType === SqlDbType.sqlserver) {
242
+ return {
243
+ insertId: _.get(queryRes, 'recordset[0].id'),
244
+ affectedRows: _.get(queryRes, 'rowsAffected[0]'),
245
+ };
246
+ }
247
+
248
+ return sqlRes;
249
+ }
250
+
251
+ //其他配置:形如: sqlRes[0].total_count
252
+ if (typeof resPicker === 'string') {
253
+ if (resPicker.startsWith('sqlRes')) {
254
+ return _.get({ sqlRes }, resPicker);
255
+ } else {
256
+ throw new CommonException(Exceptions.RUN_EXECUTE_VALIDATE, 'resPicker必须是以sqlRes开头');
257
+ }
258
+ }
259
+
260
+ return sqlRes;
261
+ }
262
+ }
263
+
264
+ export { CrudProExecuteSqlService };