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,397 +1,399 @@
1
- import {CrudProServiceBase} from './CrudProServiceBase';
2
- import {SqlCfgModel} from '../models/SqlCfgModel';
3
- import {MixinUtils} from '../utils/MixinUtils';
4
- import {SqlSegArg} from '../models/SqlSegArg';
5
- import {KeysOfCustomSQL, SqlDbType} from '../models/keys';
6
- import {RequestModel} from '../models/RequestModel';
7
- import {CommonException, Exceptions} from '../exceptions';
8
- import {RequestCfgModel} from '../models/RequestCfgModel';
9
- import {ModelUtils} from '../utils/ModelUtils';
10
- import {FuncContext} from '../models/FuncContext';
11
- import {TypeUtils} from '../utils/TypeUtils';
12
- import {sqlFuncUtils} from '../utils/SqlFuncUtils';
13
- import {toSqlColumnName, toSqlColumnNamesJoin} from '../utils/sqlConvert/convertColumnName';
14
- import {CrudProGenSqlCondition} from "./CrudProGenSqlCondition";
15
-
16
- const KEYS_CUSTOM_PATTERN = /@@[0-9a-zA-Z:._]+/gm;
17
-
18
-
19
- /**
20
- * 存在任何需要排除的
21
- * @param columns
22
- */
23
- function isAnyStartWithExclude(columns: string[]): boolean {
24
- if (MixinUtils.isEmpty(columns)) {
25
- return false;
26
- }
27
-
28
- for (let i = 0; i < columns.length; i++) {
29
- const s = columns[i];
30
- if (s.startsWith('!')) {
31
- return true;
32
- }
33
- }
34
- return false;
35
- }
36
-
37
- class CrudProOriginToExecuteSql extends CrudProServiceBase {
38
- async convertOriginToExecuteSql(sqlCfgModel: SqlCfgModel) {
39
- const originSql = sqlCfgModel.originSql;
40
- if (MixinUtils.isEmpty(originSql)) {
41
- // 允许配置中没有originSql,此时可能仅仅用来做校验逻辑
42
- return;
43
- }
44
-
45
- if (MixinUtils.isNotEmpty(sqlCfgModel.executeSql)) {
46
- //直接传递可执行SQL ,不需要再转换。
47
- return;
48
- }
49
-
50
- const sqlArgModelMap = await this.generateWordMap(originSql, sqlCfgModel);
51
-
52
- const argList = [];
53
- let executeSql = originSql;
54
-
55
-
56
- // 发现有需要被替换的变量。
57
- if (sqlArgModelMap) {
58
- executeSql = originSql.replace(KEYS_CUSTOM_PATTERN, word => {
59
- if (!word) {
60
- return '';
61
- }
62
- const sqlArgModel = sqlArgModelMap[word];
63
-
64
- if (!sqlArgModel) {
65
- return '';
66
- }
67
-
68
- if (MixinUtils.isNotEmpty(sqlArgModel.args) && Array.isArray(sqlArgModel.args)) {
69
- argList.push(...sqlArgModel.args);
70
- }
71
-
72
- return sqlArgModel.sql;
73
- });
74
- }
75
-
76
-
77
- sqlCfgModel.executeSqlArgs = argList;
78
- sqlCfgModel.executeSql = executeSql;
79
- }
80
-
81
- private async generateWordMap(originSql: string, sqlCfgModel: SqlCfgModel): Promise<Record<string, SqlSegArg>> {
82
- // ['@@columns', '@@table', '@@asWhere:condition', '@@orderBys']
83
- const sqlKeywords = originSql.match(KEYS_CUSTOM_PATTERN);
84
-
85
- // 没有需要被替换的变量。
86
- if (!sqlKeywords || sqlKeywords.length === 0) {
87
- return null;
88
- }
89
-
90
- const sqlKeywordArgModelMap = {};
91
- for (let i = 0; i < sqlKeywords.length; i++) {
92
- const word = sqlKeywords[i]; // @@columns
93
- if (word) {
94
- const sqlArgModel = await this.generateWord(word, sqlCfgModel);
95
- if (sqlArgModel) {
96
- sqlKeywordArgModelMap[word] = sqlArgModel;
97
- }
98
- }
99
- }
100
- return sqlKeywordArgModelMap;
101
- }
102
-
103
- private async generateWord(word: string, sqlCfg: SqlCfgModel): Promise<SqlSegArg> {
104
- const exeCtx = this.getExecuteContext();
105
- const reqCfg = exeCtx.getCfgModel();
106
- const reqModel = exeCtx.getReqModel();
107
-
108
- if (word === KeysOfCustomSQL.SQL_TABLE) {
109
- return this.generateTable(reqCfg, sqlCfg);
110
- } else if (word === KeysOfCustomSQL.SQL_COLUMNS) {
111
- return this.generateColumns(reqCfg, sqlCfg, reqModel);
112
- } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_WHERE)) {
113
- return this.generateCondition(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_WHERE));
114
- } else if (word === KeysOfCustomSQL.SQL_OFFSET_LIMIT) {
115
- return this.generateOffsetLimit(reqCfg, sqlCfg, reqModel);
116
- } else if (word === KeysOfCustomSQL.SQL_ORDER_BYS) {
117
- return this.generateOrderBys(reqModel, sqlCfg);
118
- } else if ((
119
- word.startsWith(KeysOfCustomSQL.SQL_GET_DATA_ATTR_START) ||
120
- word.startsWith(KeysOfCustomSQL.SQL_GET_CONDITION_ATTR_START)) && word.indexOf('.') > 0) {
121
- return this.generateGetAttr(reqModel, word); //// data.xxx, condition.xxx
122
- } else if (word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER) || word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_STRING)) {
123
- return this.generatePickResAs(reqModel, word); // @@pickResAsNumber:replies_count
124
- } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_UPDATE)) {
125
- return this.generateDataUpdate(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_UPDATE));
126
- } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_INSERT_KEYS)) {
127
- return this.generateDataAsInsertKeys(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_INSERT_KEYS));
128
- } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_INSERT_VALUES)) {
129
- return this.generateDataAsInsertValues(reqModel, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_INSERT_VALUES));
130
- } else if (word.startsWith(KeysOfCustomSQL.SQL_FUNCTION)) {
131
- return this.generateSqlJavaFunction(reqCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_FUNCTION));
132
- } else {
133
- return new SqlSegArg(word.toString());
134
- }
135
- }
136
-
137
- private generateDataAsInsertKeys(req: RequestModel, sqlCfgModel: SqlCfgModel, dataName: string): SqlSegArg {
138
- const data = req.getCondOrDataJsonObject(dataName);
139
-
140
- if (MixinUtils.isEmpty(data)) {
141
- throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_KEYS, dataName);
142
- }
143
-
144
- const keys = Object.keys(data).sort();
145
-
146
- const columnList = keys.map(columnName => {
147
- return toSqlColumnName(columnName, sqlCfgModel);
148
- });
149
-
150
- const sql = columnList.join(','); // `column1`,`column2`,`column3`,
151
- return new SqlSegArg(sql); // 只有sql,没有arg
152
- }
153
-
154
- private generateTable(requestCfg: RequestCfgModel, sqlCfgModel: SqlCfgModel): SqlSegArg {
155
- const sqlTableName = ModelUtils.getSqlTable(sqlCfgModel, requestCfg);
156
-
157
- if (MixinUtils.isEmpty(sqlTableName)) {
158
- throw new CommonException(Exceptions.CFG_EMPTY_TABLE_NAME);
159
- }
160
-
161
- const sqlSchema = ModelUtils.getSqlSchema(sqlCfgModel, requestCfg);
162
- if (MixinUtils.isNotEmpty(sqlSchema)) {
163
- return new SqlSegArg(`${toSqlColumnName(sqlSchema, sqlCfgModel)}.${toSqlColumnName(sqlTableName, sqlCfgModel)}`);
164
- }
165
- return new SqlSegArg(toSqlColumnName(sqlTableName, sqlCfgModel));
166
- }
167
-
168
- private async generateColumns(cfg: RequestCfgModel, sqlCfgModel: SqlCfgModel, req: RequestModel): Promise<SqlSegArg> {
169
- // req cfg 都没有 columns字段
170
- if (MixinUtils.isEmpty(cfg.columns) && MixinUtils.isEmpty(req.columns)) {
171
- return new SqlSegArg('*');
172
- }
173
-
174
- const cfgColumns = await this.generateCfgColumns(sqlCfgModel); // 不会为空
175
- const reqColumns = req.columns;
176
-
177
- // req 为空
178
- if (MixinUtils.isEmpty(reqColumns)) {
179
- return new SqlSegArg(toSqlColumnNamesJoin(cfgColumns, sqlCfgModel));
180
- }
181
-
182
- // req 不为空:1. 排除法
183
- // cfgColumns与reqColumns 都不为空: 使用排除法
184
- if (isAnyStartWithExclude(reqColumns)) {
185
- const result = [];
186
- for (let i = 0; i < cfgColumns.length; i++) {
187
- const cfgColumn = cfgColumns[i];
188
- if (reqColumns.indexOf('!' + cfgColumn) < 0) {
189
- result.push(cfgColumn);
190
- }
191
- }
192
- return new SqlSegArg(toSqlColumnNamesJoin(result, sqlCfgModel));
193
- }
194
-
195
- // req 不为空:2. 取交集
196
- const result = [];
197
- for (let i = 0; i < reqColumns.length; i++) {
198
- const reqColumn = reqColumns[i];
199
- if (cfgColumns.indexOf(reqColumn) >= 0) {
200
- result.push(reqColumn);
201
- }
202
- }
203
- return new SqlSegArg(toSqlColumnNamesJoin(result,sqlCfgModel));
204
- }
205
-
206
- /**
207
- * 生成查询条件
208
- * @param req
209
- * @param sqlCfg
210
- * @param conditionName
211
- * @private
212
- */
213
- private generateCondition(req: RequestModel, sqlCfg: SqlCfgModel, conditionName: any): SqlSegArg {
214
- if (MixinUtils.isEmpty(conditionName)) {
215
- conditionName = 'condition';
216
- }
217
- const condition = req.getCondOrDataJsonObject(conditionName);
218
-
219
- const ss = new CrudProGenSqlCondition(sqlCfg);
220
-
221
- return ss.generateCondition(condition);
222
- }
223
-
224
- private generateOffsetLimit(requestCfg: RequestCfgModel, sqlCfg: SqlCfgModel, req: RequestModel): SqlSegArg {
225
- const maxLimit = ModelUtils.getMaxLimit(sqlCfg, requestCfg);
226
- const reqLimit = req.limit;
227
- const limit = Math.min(maxLimit, reqLimit);
228
-
229
- if (sqlCfg.sqlDdType === SqlDbType.postgres) {
230
- return new SqlSegArg(' LIMIT ? OFFSET ? ', [limit, req.offset]);
231
- }
232
-
233
- if (sqlCfg.sqlDdType === SqlDbType.sqlserver) {
234
- return new SqlSegArg(' OFFSET ? ROWS FETCH NEXT ? ROWS ONLY ', [ req.offset, limit]);
235
- }
236
-
237
- return new SqlSegArg(' limit ?,? ', [req.offset, limit]);
238
- }
239
-
240
- // 生成排序条件
241
- private generateOrderBys(req: RequestModel, sqlCfgModel: SqlCfgModel): SqlSegArg {
242
- const orderBys = req.orderBys;
243
- if (MixinUtils.isEmpty(orderBys)) {
244
- return null;
245
- }
246
- const orderByArr = orderBys.map(orderBy => {
247
- return toSqlColumnName(orderBy.fieldName, sqlCfgModel) + ' ' + orderBy.orderType;
248
- });
249
- const sql = 'order by ' + orderByArr.join(',');
250
- return new SqlSegArg(sql);
251
- }
252
-
253
-
254
- private generatePickResAs(req: RequestModel, world: string): SqlSegArg {
255
- return new SqlSegArg(' ? ', [{
256
- ___GENERATE_GET_RES_ATTR___: world,
257
- }]);
258
- }
259
-
260
- private generateGetAttr(req: RequestModel, word: string): SqlSegArg {
261
- const attrName = MixinUtils.removeStringPrefix(word, '@@');
262
-
263
- if (MixinUtils.isEmpty(attrName)) {
264
- throw new CommonException(Exceptions.CFG_GET_ATTR_NAME_EMPTY, word);
265
- }
266
-
267
- const dataValue = req.getJsonObjectValue(attrName);
268
-
269
- if (typeof dataValue === 'undefined' || !TypeUtils.isBasicType(dataValue)) {
270
- throw new CommonException(Exceptions.CFG_GET_ATTR_VALUE_ERROR, word);
271
- }
272
-
273
- return new SqlSegArg(' ? ', [dataValue]);
274
- }
275
-
276
- private generateDataUpdate(req: RequestModel, sqlCfgModel: SqlCfgModel, dataName: string): SqlSegArg {
277
- const data = req.getCondOrDataJsonObject(dataName);
278
-
279
- if (MixinUtils.isEmpty(data)) {
280
- throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_UPDATE, dataName);
281
- }
282
-
283
- const keys = Object.keys(data).sort();
284
-
285
- const sqlList = [];
286
- const argList = [];
287
-
288
- for (let i = 0; i < keys.length; i++) {
289
- const key = keys[i];
290
- const arg = data[key];
291
- if (sqlFuncUtils.isSqlFuncArg(arg)) {
292
- const funcSQL = sqlFuncUtils.toFuncSQL(arg);
293
- sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ' + funcSQL);
294
- } else {
295
- sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ?');
296
- argList.push(arg);
297
- }
298
- }
299
-
300
- const sql = sqlList.join(',');
301
- return new SqlSegArg(sql, argList);
302
- }
303
-
304
- private generateDataAsInsertValues(req: RequestModel, dataName: string): SqlSegArg {
305
- const data = req.getCondOrDataJsonObject(dataName);
306
-
307
- if (MixinUtils.isEmpty(data)) {
308
- throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_VALUES, dataName);
309
- }
310
-
311
- const keys = Object.keys(data).sort();
312
-
313
- const sqlList = [];
314
- const argList = [];
315
-
316
- for (let i = 0; i < keys.length; i++) {
317
- const key = keys[i];
318
- const arg = data[key];
319
-
320
- // data: {xxxTime: {$byFunc:"NOW()"}}
321
- if (sqlFuncUtils.isSqlFuncArg(arg)) {
322
- const funcSQL = sqlFuncUtils.toFuncSQL(arg); // values( ? , ? , NOW() , ?)
323
- sqlList.push(funcSQL);
324
- } else {
325
- sqlList.push('?');
326
- argList.push(arg);
327
- }
328
- }
329
-
330
- const sql = sqlList.join(','); // "?,?,?,?"
331
- return new SqlSegArg(sql, argList);
332
- }
333
-
334
- private generateSqlJavaFunction(requestCfg: RequestCfgModel, tmpFuncName: string): SqlSegArg {
335
- const exeCtx = this.getExecuteContext();
336
-
337
- const functionCfg = requestCfg.functionCfg;
338
-
339
- if (MixinUtils.isEmpty(functionCfg)) {
340
- throw new CommonException(Exceptions.CFG_SQL_FUNCTION_EMPTY, tmpFuncName);
341
- }
342
-
343
- const tmpFunCfg = functionCfg[tmpFuncName];
344
-
345
- if (ModelUtils.checkFuncCfgValid(tmpFunCfg)) {
346
- throw new CommonException(Exceptions.CFG_VALIDATE_CUSTOM_FUNCTION_EMPTY, tmpFuncName);
347
- }
348
-
349
- const exeFunCtx = new FuncContext();
350
-
351
- exeFunCtx.currentValue = null;
352
- exeFunCtx.reqModel = exeCtx.getReqModel();
353
- exeFunCtx.resModel = exeCtx.getResModel();
354
-
355
- const dataValue = this.serviceHub.executeFuncCfg(tmpFunCfg, exeFunCtx);
356
-
357
- return new SqlSegArg(' ? ', [dataValue]);
358
- }
359
-
360
- /**
361
- * 不会返回空。
362
- * @param sqlCfgModel
363
- * @private
364
- */
365
- private async generateCfgColumns(sqlCfgModel: SqlCfgModel): Promise<string[]> {
366
- const tableMeta = await this.serviceHub.getTableMeta(sqlCfgModel);
367
-
368
- const tableColumns = tableMeta.tableColumns;
369
- const cfgColumns = sqlCfgModel.columns || [];
370
-
371
- // 没有配置: 全量
372
- if (MixinUtils.isEmpty(cfgColumns)) {
373
- return tableColumns;
374
- }
375
-
376
- // 黑名单:排除法
377
- if (isAnyStartWithExclude(cfgColumns)) {
378
- const excludeColumns = cfgColumns.filter(c => {
379
- return c.startsWith('!');
380
- });
381
- const excludeColumnsSet = new Set(excludeColumns);
382
- const result = [];
383
- for (let i = 0; i < tableColumns.length; i++) {
384
- const tableColumn = tableColumns[i];
385
- if (!excludeColumnsSet.has('!' + tableColumn)) {
386
- result.push(tableColumn);
387
- }
388
- }
389
- return result;
390
- }
391
-
392
- // 白名单
393
- return cfgColumns;
394
- }
395
- }
396
-
397
- export { CrudProOriginToExecuteSql };
1
+ import { CrudProServiceBase } from './CrudProServiceBase';
2
+ import { SqlCfgModel } from '../models/SqlCfgModel';
3
+ import { MixinUtils } from '../utils/MixinUtils';
4
+ import { SqlSegArg } from '../models/SqlSegArg';
5
+ import { KeysOfCustomSQL, SqlDbType } from '../models/keys';
6
+ import { RequestModel } from '../models/RequestModel';
7
+ import { CommonException, Exceptions } from '../exceptions';
8
+ import { RequestCfgModel } from '../models/RequestCfgModel';
9
+ import { ModelUtils } from '../utils/ModelUtils';
10
+ import { FuncContext } from '../models/FuncContext';
11
+ import { TypeUtils } from '../utils/TypeUtils';
12
+ import { sqlFuncUtils } from '../utils/SqlFuncUtils';
13
+ import { toSqlColumnName, toSqlColumnNamesJoin } from '../utils/sqlConvert/convertColumnName';
14
+ import { CrudProGenSqlCondition } from './CrudProGenSqlCondition';
15
+
16
+ const KEYS_CUSTOM_PATTERN = /@@[0-9a-zA-Z:._]+/gm;
17
+
18
+ /**
19
+ * 存在任何需要排除的
20
+ * @param columns
21
+ */
22
+ function isAnyStartWithExclude(columns: string[]): boolean {
23
+ if (MixinUtils.isEmpty(columns)) {
24
+ return false;
25
+ }
26
+
27
+ for (let i = 0; i < columns.length; i++) {
28
+ const s = columns[i];
29
+ if (s.startsWith('!')) {
30
+ return true;
31
+ }
32
+ }
33
+ return false;
34
+ }
35
+
36
+ class CrudProOriginToExecuteSql extends CrudProServiceBase {
37
+ async convertOriginToExecuteSql(sqlCfgModel: SqlCfgModel) {
38
+ const originSql = sqlCfgModel.originSql;
39
+ if (MixinUtils.isEmpty(originSql)) {
40
+ // 允许配置中没有originSql,此时可能仅仅用来做校验逻辑
41
+ return;
42
+ }
43
+
44
+ if (MixinUtils.isNotEmpty(sqlCfgModel.executeSql)) {
45
+ //直接传递可执行SQL ,不需要再转换。
46
+ return;
47
+ }
48
+
49
+ const sqlArgModelMap = await this.generateWordMap(originSql, sqlCfgModel);
50
+
51
+ const argList = [];
52
+ let executeSql = originSql;
53
+
54
+ // 发现有需要被替换的变量。
55
+ if (sqlArgModelMap) {
56
+ executeSql = originSql.replace(KEYS_CUSTOM_PATTERN, word => {
57
+ if (!word) {
58
+ return '';
59
+ }
60
+ const sqlArgModel = sqlArgModelMap[word];
61
+
62
+ if (!sqlArgModel) {
63
+ return '';
64
+ }
65
+
66
+ if (MixinUtils.isNotEmpty(sqlArgModel.args) && Array.isArray(sqlArgModel.args)) {
67
+ argList.push(...sqlArgModel.args);
68
+ }
69
+
70
+ return sqlArgModel.sql;
71
+ });
72
+ }
73
+
74
+ sqlCfgModel.executeSqlArgs = argList;
75
+ sqlCfgModel.executeSql = executeSql;
76
+ }
77
+
78
+ private async generateWordMap(originSql: string, sqlCfgModel: SqlCfgModel): Promise<Record<string, SqlSegArg>> {
79
+ // ['@@columns', '@@table', '@@asWhere:condition', '@@orderBys']
80
+ const sqlKeywords = originSql.match(KEYS_CUSTOM_PATTERN);
81
+
82
+ // 没有需要被替换的变量。
83
+ if (!sqlKeywords || sqlKeywords.length === 0) {
84
+ return null;
85
+ }
86
+
87
+ const sqlKeywordArgModelMap = {};
88
+ for (let i = 0; i < sqlKeywords.length; i++) {
89
+ const word = sqlKeywords[i]; // @@columns
90
+ if (word) {
91
+ const sqlArgModel = await this.generateWord(word, sqlCfgModel);
92
+ if (sqlArgModel) {
93
+ sqlKeywordArgModelMap[word] = sqlArgModel;
94
+ }
95
+ }
96
+ }
97
+ return sqlKeywordArgModelMap;
98
+ }
99
+
100
+ private async generateWord(word: string, sqlCfg: SqlCfgModel): Promise<SqlSegArg> {
101
+ const exeCtx = this.getExecuteContext();
102
+ const reqCfg = exeCtx.getCfgModel();
103
+ const reqModel = exeCtx.getReqModel();
104
+
105
+ if (word === KeysOfCustomSQL.SQL_TABLE) {
106
+ return this.generateTable(reqCfg, sqlCfg);
107
+ } else if (word === KeysOfCustomSQL.SQL_COLUMNS) {
108
+ return this.generateColumns(reqCfg, sqlCfg, reqModel);
109
+ } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_WHERE)) {
110
+ return this.generateCondition(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_WHERE));
111
+ } else if (word === KeysOfCustomSQL.SQL_OFFSET_LIMIT) {
112
+ return this.generateOffsetLimit(reqCfg, sqlCfg, reqModel);
113
+ } else if (word === KeysOfCustomSQL.SQL_ORDER_BYS) {
114
+ return this.generateOrderBys(reqModel, sqlCfg);
115
+ } else if ((word.startsWith(KeysOfCustomSQL.SQL_GET_DATA_ATTR_START) || word.startsWith(KeysOfCustomSQL.SQL_GET_CONDITION_ATTR_START)) && word.indexOf('.') > 0) {
116
+ return this.generateGetAttr(reqModel, word); //// data.xxx, condition.xxx
117
+ } else if (word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER) || word.startsWith(KeysOfCustomSQL.SQL_PICK_RES_AS_STRING)) {
118
+ return this.generatePickResAs(reqModel, word); // @@pickResAsNumber:replies_count
119
+ } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_UPDATE)) {
120
+ return this.generateDataUpdate(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_UPDATE));
121
+ } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_INSERT_KEYS)) {
122
+ return this.generateDataAsInsertKeys(reqModel, sqlCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_INSERT_KEYS));
123
+ } else if (word.startsWith(KeysOfCustomSQL.SQL_AS_INSERT_VALUES)) {
124
+ return this.generateDataAsInsertValues(reqModel, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_AS_INSERT_VALUES));
125
+ } else if (word.startsWith(KeysOfCustomSQL.SQL_FUNCTION)) {
126
+ return this.generateSqlJavaFunction(reqCfg, MixinUtils.removeStringPrefix(word, KeysOfCustomSQL.SQL_FUNCTION));
127
+ } else {
128
+ return new SqlSegArg(word.toString());
129
+ }
130
+ }
131
+
132
+ private generateDataAsInsertKeys(req: RequestModel, sqlCfgModel: SqlCfgModel, dataName: string): SqlSegArg {
133
+ const data = req.getCondOrDataJsonObject(dataName);
134
+
135
+ if (MixinUtils.isEmpty(data)) {
136
+ throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_KEYS, dataName);
137
+ }
138
+
139
+ const keys = Object.keys(data).sort();
140
+
141
+ const columnList = keys.map(columnName => {
142
+ return toSqlColumnName(columnName, sqlCfgModel);
143
+ });
144
+
145
+ const sql = columnList.join(','); // `column1`,`column2`,`column3`,
146
+ return new SqlSegArg(sql); // 只有sql,没有arg
147
+ }
148
+
149
+ private generateTable(requestCfg: RequestCfgModel, sqlCfgModel: SqlCfgModel): SqlSegArg {
150
+ const sqlTableName = ModelUtils.getSqlTable(sqlCfgModel, requestCfg);
151
+
152
+ if (MixinUtils.isEmpty(sqlTableName)) {
153
+ throw new CommonException(Exceptions.CFG_EMPTY_TABLE_NAME);
154
+ }
155
+
156
+ const sqlSchema = ModelUtils.getSqlSchema(sqlCfgModel, requestCfg);
157
+ if (MixinUtils.isNotEmpty(sqlSchema)) {
158
+ return new SqlSegArg(`${toSqlColumnName(sqlSchema, sqlCfgModel)}.${toSqlColumnName(sqlTableName, sqlCfgModel)}`);
159
+ }
160
+ return new SqlSegArg(toSqlColumnName(sqlTableName, sqlCfgModel));
161
+ }
162
+
163
+ private async generateColumns(cfg: RequestCfgModel, sqlCfgModel: SqlCfgModel, req: RequestModel): Promise<SqlSegArg> {
164
+ // req 和 cfg 都没有 columns字段
165
+ if (MixinUtils.isEmpty(cfg.columns) && MixinUtils.isEmpty(req.columns)) {
166
+ return new SqlSegArg('*');
167
+ }
168
+
169
+ const cfgColumns = await this.generateCfgColumns(sqlCfgModel); // 不会为空
170
+ const reqColumns = req.columns;
171
+
172
+ // req 为空
173
+ if (MixinUtils.isEmpty(reqColumns)) {
174
+ return new SqlSegArg(toSqlColumnNamesJoin(cfgColumns, sqlCfgModel));
175
+ }
176
+
177
+ // req 不为空:1. 排除法
178
+ // cfgColumns与reqColumns 都不为空: 使用排除法
179
+ if (isAnyStartWithExclude(reqColumns)) {
180
+ const result = [];
181
+ for (let i = 0; i < cfgColumns.length; i++) {
182
+ const cfgColumn = cfgColumns[i];
183
+ if (reqColumns.indexOf('!' + cfgColumn) < 0) {
184
+ result.push(cfgColumn);
185
+ }
186
+ }
187
+ return new SqlSegArg(toSqlColumnNamesJoin(result, sqlCfgModel));
188
+ }
189
+
190
+ // req 不为空:2. 取交集
191
+ const result = [];
192
+ for (let i = 0; i < reqColumns.length; i++) {
193
+ const reqColumn = reqColumns[i];
194
+ if (cfgColumns.indexOf(reqColumn) >= 0) {
195
+ result.push(reqColumn);
196
+ }
197
+ }
198
+ return new SqlSegArg(toSqlColumnNamesJoin(result, sqlCfgModel));
199
+ }
200
+
201
+ /**
202
+ * 生成查询条件
203
+ * @param req
204
+ * @param sqlCfg
205
+ * @param conditionName
206
+ * @private
207
+ */
208
+ private generateCondition(req: RequestModel, sqlCfg: SqlCfgModel, conditionName: any): SqlSegArg {
209
+ if (MixinUtils.isEmpty(conditionName)) {
210
+ conditionName = 'condition';
211
+ }
212
+ const condition = req.getCondOrDataJsonObject(conditionName);
213
+
214
+ const ss = new CrudProGenSqlCondition(sqlCfg);
215
+
216
+ return ss.generateCondition(condition);
217
+ }
218
+
219
+ private generateOffsetLimit(requestCfg: RequestCfgModel, sqlCfg: SqlCfgModel, req: RequestModel): SqlSegArg {
220
+ const maxLimit = ModelUtils.getMaxLimit(sqlCfg, requestCfg);
221
+ const reqLimit = req.limit;
222
+ const limit = Math.min(maxLimit, reqLimit);
223
+
224
+ if (sqlCfg.sqlDbType === SqlDbType.postgres) {
225
+ return new SqlSegArg(' LIMIT ? OFFSET ? ', [limit, req.offset]);
226
+ }
227
+
228
+ if (sqlCfg.sqlDbType === SqlDbType.sqlserver) {
229
+ return new SqlSegArg(' OFFSET ? ROWS FETCH NEXT ? ROWS ONLY ', [req.offset, limit]);
230
+ }
231
+
232
+ return new SqlSegArg(' limit ?,? ', [req.offset, limit]);
233
+ }
234
+
235
+ // 生成排序条件
236
+ private generateOrderBys(req: RequestModel, sqlCfgModel: SqlCfgModel): SqlSegArg {
237
+ const orderBys = req.orderBys;
238
+ if (MixinUtils.isEmpty(orderBys)) {
239
+ return null;
240
+ }
241
+ const ORDER_BY_TYPE_ARR = ['asc', 'desc'];
242
+
243
+ const orderByArr = orderBys.map(orderBy => {
244
+ const orderType = (orderBy.orderType || 'asc').toLowerCase();
245
+ if (!ORDER_BY_TYPE_ARR.includes(orderType)) {
246
+ throw new CommonException(Exceptions.CFG_ORDER_BY_TYPE_ERROR, 'orderType must be asc or desc : ' + orderType);
247
+ }
248
+ return toSqlColumnName(orderBy.fieldName, sqlCfgModel) + ' ' + orderType;
249
+ });
250
+ const sql = 'order by ' + orderByArr.join(',');
251
+ return new SqlSegArg(sql);
252
+ }
253
+
254
+ private generatePickResAs(req: RequestModel, world: string): SqlSegArg {
255
+ return new SqlSegArg(' ? ', [
256
+ {
257
+ ___GENERATE_GET_RES_ATTR___: world,
258
+ },
259
+ ]);
260
+ }
261
+
262
+ private generateGetAttr(req: RequestModel, word: string): SqlSegArg {
263
+ const attrName = MixinUtils.removeStringPrefix(word, '@@');
264
+
265
+ if (MixinUtils.isEmpty(attrName)) {
266
+ throw new CommonException(Exceptions.CFG_GET_ATTR_NAME_EMPTY, word);
267
+ }
268
+
269
+ const dataValue = req.getJsonObjectValue(attrName);
270
+
271
+ if (typeof dataValue === 'undefined' || !TypeUtils.isBasicType(dataValue)) {
272
+ throw new CommonException(Exceptions.CFG_GET_ATTR_VALUE_ERROR, word);
273
+ }
274
+
275
+ return new SqlSegArg(' ? ', [dataValue]);
276
+ }
277
+
278
+ private generateDataUpdate(req: RequestModel, sqlCfgModel: SqlCfgModel, dataName: string): SqlSegArg {
279
+ const data = req.getCondOrDataJsonObject(dataName);
280
+
281
+ if (MixinUtils.isEmpty(data)) {
282
+ throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_UPDATE, dataName);
283
+ }
284
+
285
+ const keys = Object.keys(data).sort();
286
+
287
+ const sqlList = [];
288
+ const argList = [];
289
+
290
+ for (let i = 0; i < keys.length; i++) {
291
+ const key = keys[i];
292
+ const arg = data[key];
293
+ if (sqlFuncUtils.isSqlFuncArg(arg)) {
294
+ const funcSQL = sqlFuncUtils.toFuncSQL(arg);
295
+ sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ' + funcSQL);
296
+ } else {
297
+ sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ?');
298
+ argList.push(arg);
299
+ }
300
+ }
301
+
302
+ const sql = sqlList.join(',');
303
+ return new SqlSegArg(sql, argList);
304
+ }
305
+
306
+ private generateDataAsInsertValues(req: RequestModel, dataName: string): SqlSegArg {
307
+ const data = req.getCondOrDataJsonObject(dataName);
308
+
309
+ if (MixinUtils.isEmpty(data)) {
310
+ throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_VALUES, dataName);
311
+ }
312
+
313
+ const keys = Object.keys(data).sort();
314
+
315
+ const sqlList = [];
316
+ const argList = [];
317
+
318
+ for (let i = 0; i < keys.length; i++) {
319
+ const key = keys[i];
320
+ const arg = data[key];
321
+
322
+ // data: {xxxTime: {$byFunc:"NOW()"}}
323
+ if (sqlFuncUtils.isSqlFuncArg(arg)) {
324
+ const funcSQL = sqlFuncUtils.toFuncSQL(arg); // values( ? , ? , NOW() , ?)
325
+ sqlList.push(funcSQL);
326
+ } else {
327
+ sqlList.push('?');
328
+ argList.push(arg);
329
+ }
330
+ }
331
+
332
+ const sql = sqlList.join(','); // "?,?,?,?"
333
+ return new SqlSegArg(sql, argList);
334
+ }
335
+
336
+ private generateSqlJavaFunction(requestCfg: RequestCfgModel, tmpFuncName: string): SqlSegArg {
337
+ const exeCtx = this.getExecuteContext();
338
+
339
+ const functionCfg = requestCfg.functionCfg;
340
+
341
+ if (MixinUtils.isEmpty(functionCfg)) {
342
+ throw new CommonException(Exceptions.CFG_SQL_FUNCTION_EMPTY, tmpFuncName);
343
+ }
344
+
345
+ const tmpFunCfg = functionCfg[tmpFuncName];
346
+
347
+ if (ModelUtils.checkFuncCfgValid(tmpFunCfg)) {
348
+ throw new CommonException(Exceptions.CFG_VALIDATE_CUSTOM_FUNCTION_EMPTY, tmpFuncName);
349
+ }
350
+
351
+ const exeFunCtx = new FuncContext();
352
+
353
+ exeFunCtx.currentValue = null;
354
+ exeFunCtx.reqModel = exeCtx.getReqModel();
355
+ exeFunCtx.resModel = exeCtx.getResModel();
356
+
357
+ const dataValue = this.serviceHub.executeFuncCfg(tmpFunCfg, exeFunCtx);
358
+
359
+ return new SqlSegArg(' ? ', [dataValue]);
360
+ }
361
+
362
+ /**
363
+ * 不会返回空。
364
+ * @param sqlCfgModel
365
+ * @private
366
+ */
367
+ private async generateCfgColumns(sqlCfgModel: SqlCfgModel): Promise<string[]> {
368
+ const tableMeta = await this.serviceHub.getTableMeta(sqlCfgModel);
369
+
370
+ const tableColumns = tableMeta.tableColumns;
371
+ const cfgColumns = sqlCfgModel.columns || [];
372
+
373
+ // 没有配置: 全量
374
+ if (MixinUtils.isEmpty(cfgColumns)) {
375
+ return tableColumns;
376
+ }
377
+
378
+ // 黑名单:排除法
379
+ if (isAnyStartWithExclude(cfgColumns)) {
380
+ const excludeColumns = cfgColumns.filter(c => {
381
+ return c.startsWith('!');
382
+ });
383
+ const excludeColumnsSet = new Set(excludeColumns);
384
+ const result = [];
385
+ for (let i = 0; i < tableColumns.length; i++) {
386
+ const tableColumn = tableColumns[i];
387
+ if (!excludeColumnsSet.has('!' + tableColumn)) {
388
+ result.push(tableColumn);
389
+ }
390
+ }
391
+ return result;
392
+ }
393
+
394
+ // 白名单
395
+ return cfgColumns;
396
+ }
397
+ }
398
+
399
+ export { CrudProOriginToExecuteSql };