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