midway-fatcms 0.0.1-beta.55 → 0.0.1-beta.56

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 (497) hide show
  1. package/.eslintrc.json +14 -14
  2. package/.prettierrc.js +4 -4
  3. package/README.md +8 -8
  4. package/dist/config/config.default.d.ts +3 -3
  5. package/dist/config/config.default.js +160 -160
  6. package/dist/config/utils.d.ts +1 -1
  7. package/dist/config/utils.js +23 -23
  8. package/dist/configuration.d.ts +7 -7
  9. package/dist/configuration.js +113 -113
  10. package/dist/controller/base/BaseApiController.d.ts +37 -37
  11. package/dist/controller/base/BaseApiController.js +164 -164
  12. package/dist/controller/gateway/AnyApiGatewayController.d.ts +13 -13
  13. package/dist/controller/gateway/AnyApiGatewayController.js +55 -55
  14. package/dist/controller/gateway/AsyncTaskController.d.ts +20 -20
  15. package/dist/controller/gateway/AsyncTaskController.js +181 -181
  16. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
  17. package/dist/controller/gateway/CrudMtdGatewayController.js +122 -119
  18. package/dist/controller/gateway/CrudStdGatewayController.d.ts +38 -38
  19. package/dist/controller/gateway/CrudStdGatewayController.js +129 -129
  20. package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
  21. package/dist/controller/gateway/DocGatewayController.js +179 -179
  22. package/dist/controller/gateway/FileController.d.ts +26 -26
  23. package/dist/controller/gateway/FileController.js +129 -129
  24. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
  25. package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
  26. package/dist/controller/gateway/PublicApiController.d.ts +27 -27
  27. package/dist/controller/gateway/PublicApiController.js +162 -162
  28. package/dist/controller/gateway/StaticController.d.ts +23 -23
  29. package/dist/controller/gateway/StaticController.js +286 -286
  30. package/dist/controller/helpers.controller.d.ts +39 -39
  31. package/dist/controller/helpers.controller.js +188 -188
  32. package/dist/controller/home.controller.d.ts +9 -9
  33. package/dist/controller/home.controller.js +72 -72
  34. package/dist/controller/manage/AnyApiMangeApi.d.ts +10 -10
  35. package/dist/controller/manage/AnyApiMangeApi.js +98 -98
  36. package/dist/controller/manage/AppLogMangeApi.d.ts +10 -10
  37. package/dist/controller/manage/AppLogMangeApi.js +88 -88
  38. package/dist/controller/manage/AppMangeApi.d.ts +10 -10
  39. package/dist/controller/manage/AppMangeApi.js +88 -88
  40. package/dist/controller/manage/AppPageMangeApi.d.ts +10 -10
  41. package/dist/controller/manage/AppPageMangeApi.js +87 -87
  42. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +10 -10
  43. package/dist/controller/manage/AppSchemaHistoryApi.js +83 -83
  44. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +10 -10
  45. package/dist/controller/manage/CrudMethodsMangeApi.js +84 -84
  46. package/dist/controller/manage/CrudStandardDesignApi.d.ts +46 -46
  47. package/dist/controller/manage/CrudStandardDesignApi.js +395 -395
  48. package/dist/controller/manage/DataDictManageApi.d.ts +15 -15
  49. package/dist/controller/manage/DataDictManageApi.js +133 -133
  50. package/dist/controller/manage/DeployManageApi.d.ts +19 -19
  51. package/dist/controller/manage/DeployManageApi.js +180 -180
  52. package/dist/controller/manage/DocLibManageApi.d.ts +10 -10
  53. package/dist/controller/manage/DocLibManageApi.js +104 -104
  54. package/dist/controller/manage/DocManageApi.d.ts +11 -11
  55. package/dist/controller/manage/DocManageApi.js +130 -130
  56. package/dist/controller/manage/FileManageApi.d.ts +13 -13
  57. package/dist/controller/manage/FileManageApi.js +77 -77
  58. package/dist/controller/manage/LowCodeTplManageApi.d.ts +13 -13
  59. package/dist/controller/manage/LowCodeTplManageApi.js +86 -86
  60. package/dist/controller/manage/MenuManageApi.d.ts +10 -10
  61. package/dist/controller/manage/MenuManageApi.js +93 -93
  62. package/dist/controller/manage/ProxyApiMangeApi.d.ts +10 -10
  63. package/dist/controller/manage/ProxyApiMangeApi.js +87 -87
  64. package/dist/controller/manage/SuperAdminManageApi.d.ts +24 -24
  65. package/dist/controller/manage/SuperAdminManageApi.js +153 -153
  66. package/dist/controller/manage/SysConfigMangeApi.d.ts +11 -11
  67. package/dist/controller/manage/SysConfigMangeApi.js +126 -126
  68. package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
  69. package/dist/controller/manage/SystemInfoManageApi.js +72 -72
  70. package/dist/controller/manage/UserAccountManageApi.d.ts +14 -14
  71. package/dist/controller/manage/UserAccountManageApi.js +129 -129
  72. package/dist/controller/manage/WorkbenchMangeApi.d.ts +11 -11
  73. package/dist/controller/manage/WorkbenchMangeApi.js +103 -103
  74. package/dist/controller/myinfo/AuthController.d.ts +33 -33
  75. package/dist/controller/myinfo/AuthController.js +136 -136
  76. package/dist/controller/myinfo/MyInfoController.d.ts +13 -13
  77. package/dist/controller/myinfo/MyInfoController.js +51 -51
  78. package/dist/controller/render/AppRenderController.d.ts +11 -11
  79. package/dist/controller/render/AppRenderController.js +92 -92
  80. package/dist/controller/test.controller.d.ts +8 -8
  81. package/dist/controller/test.controller.js +51 -51
  82. package/dist/filter/default.filter.d.ts +7 -7
  83. package/dist/filter/default.filter.js +23 -23
  84. package/dist/filter/notfound.filter.d.ts +5 -5
  85. package/dist/filter/notfound.filter.js +20 -20
  86. package/dist/index.d.ts +103 -103
  87. package/dist/index.js +121 -121
  88. package/dist/interface.d.ts +27 -27
  89. package/dist/interface.js +3 -3
  90. package/dist/libs/crud-pro/CrudPro.d.ts +37 -37
  91. package/dist/libs/crud-pro/CrudPro.js +136 -136
  92. package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
  93. package/dist/libs/crud-pro/defaultConfigs.js +15 -15
  94. package/dist/libs/crud-pro/exceptions.d.ts +104 -104
  95. package/dist/libs/crud-pro/exceptions.js +117 -117
  96. package/dist/libs/crud-pro/interfaces.d.ts +163 -163
  97. package/dist/libs/crud-pro/interfaces.js +12 -12
  98. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -49
  99. package/dist/libs/crud-pro/models/ExecuteContext.js +79 -79
  100. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -38
  101. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -72
  102. package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
  103. package/dist/libs/crud-pro/models/FuncContext.js +6 -6
  104. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
  105. package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
  106. package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
  107. package/dist/libs/crud-pro/models/RequestModel.js +113 -113
  108. package/dist/libs/crud-pro/models/ResModel.d.ts +16 -16
  109. package/dist/libs/crud-pro/models/ResModel.js +2 -2
  110. package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
  111. package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
  112. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +22 -22
  113. package/dist/libs/crud-pro/models/SqlCfgModel.js +40 -40
  114. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +6 -6
  115. package/dist/libs/crud-pro/models/SqlSegArg.js +12 -12
  116. package/dist/libs/crud-pro/models/Transaction.d.ts +30 -30
  117. package/dist/libs/crud-pro/models/Transaction.js +74 -74
  118. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +28 -28
  119. package/dist/libs/crud-pro/models/TransactionMySQL.js +76 -76
  120. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +28 -28
  121. package/dist/libs/crud-pro/models/TransactionPostgres.js +85 -85
  122. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +34 -34
  123. package/dist/libs/crud-pro/models/TransactionSqlServer.js +92 -92
  124. package/dist/libs/crud-pro/models/keys.d.ts +106 -106
  125. package/dist/libs/crud-pro/models/keys.js +149 -149
  126. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -11
  127. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -73
  128. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
  129. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +112 -112
  130. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
  131. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -225
  132. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +9 -9
  133. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +51 -51
  134. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +13 -13
  135. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +148 -148
  136. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +24 -24
  137. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +340 -340
  138. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
  139. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -165
  140. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
  141. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +334 -334
  142. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -24
  143. package/dist/libs/crud-pro/services/CrudProServiceBase.js +90 -90
  144. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -9
  145. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +72 -72
  146. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +32 -32
  147. package/dist/libs/crud-pro/services/CurdProServiceHub.js +64 -64
  148. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +9 -9
  149. package/dist/libs/crud-pro/utils/CompareUtils.js +25 -25
  150. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +9 -9
  151. package/dist/libs/crud-pro/utils/DatabaseName.js +50 -50
  152. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +7 -7
  153. package/dist/libs/crud-pro/utils/DateTimeUtils.js +21 -21
  154. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +19 -19
  155. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +47 -47
  156. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +5 -5
  157. package/dist/libs/crud-pro/utils/MessageParseUtils.js +33 -33
  158. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +39 -39
  159. package/dist/libs/crud-pro/utils/MixinUtils.js +255 -255
  160. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +11 -11
  161. package/dist/libs/crud-pro/utils/ModelUtils.js +49 -49
  162. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +11 -11
  163. package/dist/libs/crud-pro/utils/MultiKeyMap.js +63 -63
  164. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +5 -5
  165. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +29 -29
  166. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +40 -40
  167. package/dist/libs/crud-pro/utils/TypeUtils.js +166 -166
  168. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +3 -3
  169. package/dist/libs/crud-pro/utils/ValidateUtils.js +165 -165
  170. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +3 -3
  171. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +19 -19
  172. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +3 -3
  173. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +20 -20
  174. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +3 -3
  175. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +20 -20
  176. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +4 -4
  177. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +21 -21
  178. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -3
  179. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -22
  180. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +2 -2
  181. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +11 -11
  182. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  183. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +11 -11
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +2 -2
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +128 -128
  186. package/dist/libs/global-config/global-config.d.ts +69 -60
  187. package/dist/libs/global-config/global-config.js +36 -35
  188. package/dist/libs/utils/base64.d.ts +9 -9
  189. package/dist/libs/utils/base64.js +42 -42
  190. package/dist/libs/utils/common-dto.d.ts +18 -18
  191. package/dist/libs/utils/common-dto.js +40 -40
  192. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  193. package/dist/libs/utils/crypto-utils.js +46 -46
  194. package/dist/libs/utils/errorToString.d.ts +2 -2
  195. package/dist/libs/utils/errorToString.js +57 -57
  196. package/dist/libs/utils/fatcms-request.d.ts +30 -30
  197. package/dist/libs/utils/fatcms-request.js +104 -104
  198. package/dist/libs/utils/functions.d.ts +5 -5
  199. package/dist/libs/utils/functions.js +72 -72
  200. package/dist/libs/utils/ordernum-utils.d.ts +2 -2
  201. package/dist/libs/utils/ordernum-utils.js +13 -13
  202. package/dist/libs/utils/parseConfig.d.ts +7 -7
  203. package/dist/libs/utils/parseConfig.js +44 -44
  204. package/dist/libs/utils/parseCreateSql.d.ts +10 -10
  205. package/dist/libs/utils/parseCreateSql.js +87 -87
  206. package/dist/libs/utils/render-utils.d.ts +28 -28
  207. package/dist/libs/utils/render-utils.js +135 -135
  208. package/dist/middleware/forbidden.middleware.d.ts +10 -10
  209. package/dist/middleware/forbidden.middleware.js +54 -54
  210. package/dist/middleware/global.middleware.d.ts +10 -10
  211. package/dist/middleware/global.middleware.js +266 -266
  212. package/dist/middleware/permission.middleware.d.ts +18 -18
  213. package/dist/middleware/permission.middleware.js +74 -74
  214. package/dist/middleware/rediscache.middleware.d.ts +3 -3
  215. package/dist/middleware/rediscache.middleware.js +77 -77
  216. package/dist/middleware/redislock.middleware.d.ts +7 -7
  217. package/dist/middleware/redislock.middleware.js +72 -72
  218. package/dist/middleware/tx.middleware.d.ts +9 -9
  219. package/dist/middleware/tx.middleware.js +40 -40
  220. package/dist/models/AsyncTaskModel.d.ts +74 -74
  221. package/dist/models/AsyncTaskModel.js +31 -31
  222. package/dist/models/RedisKeys.d.ts +15 -15
  223. package/dist/models/RedisKeys.js +18 -18
  224. package/dist/models/SystemEntities.d.ts +105 -105
  225. package/dist/models/SystemEntities.js +9 -9
  226. package/dist/models/SystemPerm.d.ts +95 -95
  227. package/dist/models/SystemPerm.js +100 -100
  228. package/dist/models/SystemTables.d.ts +25 -25
  229. package/dist/models/SystemTables.js +28 -28
  230. package/dist/models/bizmodels.d.ts +99 -99
  231. package/dist/models/bizmodels.js +39 -39
  232. package/dist/models/contextLogger.d.ts +25 -25
  233. package/dist/models/contextLogger.js +112 -112
  234. package/dist/models/devops.d.ts +12 -12
  235. package/dist/models/devops.js +19 -19
  236. package/dist/models/userSession.d.ts +62 -62
  237. package/dist/models/userSession.js +165 -165
  238. package/dist/schedule/anonymousContext.d.ts +14 -14
  239. package/dist/schedule/anonymousContext.js +59 -59
  240. package/dist/schedule/index.d.ts +4 -4
  241. package/dist/schedule/index.js +10 -10
  242. package/dist/schedule/runSchedule.d.ts +12 -12
  243. package/dist/schedule/runSchedule.js +68 -68
  244. package/dist/schedule/scheduleNames.d.ts +13 -13
  245. package/dist/schedule/scheduleNames.js +17 -17
  246. package/dist/service/AuthService.d.ts +71 -71
  247. package/dist/service/AuthService.js +259 -259
  248. package/dist/service/EnumInfoService.d.ts +30 -30
  249. package/dist/service/EnumInfoService.js +127 -127
  250. package/dist/service/FileCenterService.d.ts +43 -43
  251. package/dist/service/FileCenterService.js +351 -351
  252. package/dist/service/SysConfigService.d.ts +7 -7
  253. package/dist/service/SysConfigService.js +47 -47
  254. package/dist/service/UserAccountService.d.ts +23 -23
  255. package/dist/service/UserAccountService.js +107 -107
  256. package/dist/service/UserSessionService.d.ts +38 -38
  257. package/dist/service/UserSessionService.js +157 -157
  258. package/dist/service/VisitStatService.d.ts +14 -14
  259. package/dist/service/VisitStatService.js +158 -158
  260. package/dist/service/WorkbenchService.d.ts +53 -53
  261. package/dist/service/WorkbenchService.js +211 -211
  262. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  263. package/dist/service/anyapi/AnyApiSandboxService.js +110 -110
  264. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  265. package/dist/service/anyapi/AnyApiService.js +181 -181
  266. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -50
  267. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -287
  268. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -7
  269. package/dist/service/asyncTask/AsyncTaskService.js +34 -34
  270. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -10
  271. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -2
  272. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -7
  273. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -216
  274. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -36
  275. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -141
  276. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -46
  277. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -135
  278. package/dist/service/base/ApiBaseService.d.ts +15 -15
  279. package/dist/service/base/ApiBaseService.js +50 -50
  280. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  281. package/dist/service/base/ApiRateLimiter.js +51 -51
  282. package/dist/service/base/BaseService.d.ts +41 -41
  283. package/dist/service/base/BaseService.js +101 -101
  284. package/dist/service/base/RedisCacheService.d.ts +20 -20
  285. package/dist/service/base/RedisCacheService.js +57 -57
  286. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  287. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  288. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  289. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  290. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  291. package/dist/service/crudstd/CrudStdRelationService.js +112 -112
  292. package/dist/service/crudstd/CrudStdService.d.ts +68 -68
  293. package/dist/service/crudstd/CrudStdService.js +347 -347
  294. package/dist/service/curd/CrudProQuick.d.ts +44 -44
  295. package/dist/service/curd/CrudProQuick.js +147 -147
  296. package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
  297. package/dist/service/curd/CurdMixByAccountService.js +92 -92
  298. package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
  299. package/dist/service/curd/CurdMixByDictService.js +114 -114
  300. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -31
  301. package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -203
  302. package/dist/service/curd/CurdMixBySysConfigService.d.ts +9 -9
  303. package/dist/service/curd/CurdMixBySysConfigService.js +80 -80
  304. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +10 -10
  305. package/dist/service/curd/CurdMixByWorkbenchService.js +78 -78
  306. package/dist/service/curd/CurdMixService.d.ts +28 -28
  307. package/dist/service/curd/CurdMixService.js +100 -100
  308. package/dist/service/curd/CurdMixUtils.d.ts +51 -51
  309. package/dist/service/curd/CurdMixUtils.js +277 -277
  310. package/dist/service/curd/CurdProService.d.ts +32 -32
  311. package/dist/service/curd/CurdProService.js +212 -212
  312. package/dist/service/curd/fixCfgModel.d.ts +3 -3
  313. package/dist/service/curd/fixCfgModel.js +104 -104
  314. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  315. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  316. package/dist/service/proxyapi/ProxyApiService.d.ts +61 -61
  317. package/dist/service/proxyapi/ProxyApiService.js +294 -294
  318. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  319. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  320. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  321. package/dist/service/proxyapi/RouteHandler.js +9 -9
  322. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  323. package/dist/service/proxyapi/RouteTrie.js +63 -63
  324. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  325. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  326. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  327. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  328. package/index.d.ts +10 -10
  329. package/package.json +87 -81
  330. package/src/config/config.default.ts +179 -0
  331. package/src/config/seed/aeskey.txt +1 -0
  332. package/src/config/utils.ts +22 -0
  333. package/src/configuration.ts +109 -0
  334. package/src/controller/base/BaseApiController.ts +170 -0
  335. package/src/controller/gateway/AnyApiGatewayController.ts +1 -0
  336. package/src/controller/gateway/AsyncTaskController.ts +157 -0
  337. package/src/controller/gateway/CrudMtdGatewayController.ts +116 -0
  338. package/src/controller/gateway/CrudStdGatewayController.ts +87 -0
  339. package/src/controller/gateway/DocGatewayController.ts +173 -0
  340. package/src/controller/gateway/FileController.ts +109 -0
  341. package/src/controller/gateway/ProxyApiGatewayController.ts +47 -0
  342. package/src/controller/gateway/PublicApiController.ts +140 -0
  343. package/src/controller/gateway/StaticController.ts +296 -0
  344. package/src/controller/helpers.controller.ts +161 -0
  345. package/src/controller/home.controller.ts +66 -0
  346. package/src/controller/manage/AnyApiMangeApi.ts +66 -0
  347. package/src/controller/manage/AppLogMangeApi.ts +53 -0
  348. package/src/controller/manage/AppMangeApi.ts +53 -0
  349. package/src/controller/manage/AppPageMangeApi.ts +52 -0
  350. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -0
  351. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -0
  352. package/src/controller/manage/CrudStandardDesignApi.ts +406 -0
  353. package/src/controller/manage/DataDictManageApi.ts +78 -0
  354. package/src/controller/manage/DeployManageApi.ts +175 -0
  355. package/src/controller/manage/DocLibManageApi.ts +69 -0
  356. package/src/controller/manage/DocManageApi.ts +99 -0
  357. package/src/controller/manage/FileManageApi.ts +45 -0
  358. package/src/controller/manage/LowCodeTplManageApi.ts +52 -0
  359. package/src/controller/manage/MenuManageApi.ts +58 -0
  360. package/src/controller/manage/ProxyApiMangeApi.ts +52 -0
  361. package/src/controller/manage/SuperAdminManageApi.ts +139 -0
  362. package/src/controller/manage/SysConfigMangeApi.ts +95 -0
  363. package/src/controller/manage/SystemInfoManageApi.ts +53 -0
  364. package/src/controller/manage/UserAccountManageApi.ts +94 -0
  365. package/src/controller/manage/WorkbenchMangeApi.ts +72 -0
  366. package/src/controller/myinfo/AuthController.ts +108 -0
  367. package/src/controller/myinfo/MyInfoController.ts +32 -0
  368. package/src/controller/render/AppRenderController.ts +81 -0
  369. package/src/controller/test.controller.ts +37 -0
  370. package/src/filter/default.filter.ts +13 -0
  371. package/src/filter/notfound.filter.ts +10 -0
  372. package/src/index.ts +107 -0
  373. package/src/interface.ts +31 -0
  374. package/src/libs/crud-pro/CrudPro.ts +165 -0
  375. package/src/libs/crud-pro/defaultConfigs.ts +15 -0
  376. package/src/libs/crud-pro/exceptions.ts +124 -0
  377. package/src/libs/crud-pro/interfaces.ts +190 -0
  378. package/src/libs/crud-pro/models/ExecuteContext.ts +120 -0
  379. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +96 -0
  380. package/src/libs/crud-pro/models/FuncContext.ts +21 -0
  381. package/src/libs/crud-pro/models/RequestCfgModel.ts +141 -0
  382. package/src/libs/crud-pro/models/RequestModel.ts +141 -0
  383. package/src/libs/crud-pro/models/ResModel.ts +19 -0
  384. package/src/libs/crud-pro/models/ServiceHub.ts +32 -0
  385. package/src/libs/crud-pro/models/SqlCfgModel.ts +52 -0
  386. package/src/libs/crud-pro/models/SqlSegArg.ts +13 -0
  387. package/src/libs/crud-pro/models/Transaction.ts +83 -0
  388. package/src/libs/crud-pro/models/TransactionMySQL.ts +79 -0
  389. package/src/libs/crud-pro/models/TransactionPostgres.ts +91 -0
  390. package/src/libs/crud-pro/models/TransactionSqlServer.ts +102 -0
  391. package/src/libs/crud-pro/models/keys.ts +159 -0
  392. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +83 -0
  393. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +128 -0
  394. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +262 -0
  395. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +60 -0
  396. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +180 -0
  397. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +354 -0
  398. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +185 -0
  399. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +393 -0
  400. package/src/libs/crud-pro/services/CrudProServiceBase.ts +107 -0
  401. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -0
  402. package/src/libs/crud-pro/services/CurdProServiceHub.ts +92 -0
  403. package/src/libs/crud-pro/sql.txt +120 -0
  404. package/src/libs/crud-pro/utils/CompareUtils.ts +23 -0
  405. package/src/libs/crud-pro/utils/DatabaseName.ts +60 -0
  406. package/src/libs/crud-pro/utils/DateTimeUtils.ts +20 -0
  407. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +64 -0
  408. package/src/libs/crud-pro/utils/MessageParseUtils.ts +33 -0
  409. package/src/libs/crud-pro/utils/MixinUtils.ts +285 -0
  410. package/src/libs/crud-pro/utils/ModelUtils.ts +55 -0
  411. package/src/libs/crud-pro/utils/MultiKeyMap.ts +72 -0
  412. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +29 -0
  413. package/src/libs/crud-pro/utils/TypeUtils.ts +188 -0
  414. package/src/libs/crud-pro/utils/ValidateUtils.ts +165 -0
  415. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +20 -0
  416. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +22 -0
  417. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +22 -0
  418. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +26 -0
  419. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +26 -0
  420. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +11 -0
  421. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +11 -0
  422. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +129 -0
  423. package/src/libs/global-config/global-config.ts +109 -0
  424. package/src/libs/utils/base64.ts +47 -0
  425. package/src/libs/utils/common-dto.ts +52 -0
  426. package/src/libs/utils/crypto-utils.ts +50 -0
  427. package/src/libs/utils/errorToString.ts +61 -0
  428. package/src/libs/utils/fatcms-request.ts +103 -0
  429. package/src/libs/utils/functions.ts +78 -0
  430. package/src/libs/utils/ordernum-utils.ts +14 -0
  431. package/src/libs/utils/parseConfig.ts +54 -0
  432. package/src/libs/utils/parseCreateSql.ts +91 -0
  433. package/src/libs/utils/render-utils.ts +184 -0
  434. package/src/middleware/forbidden.middleware.ts +52 -0
  435. package/src/middleware/global.middleware.ts +293 -0
  436. package/src/middleware/permission.middleware.ts +80 -0
  437. package/src/middleware/rediscache.middleware.ts +91 -0
  438. package/src/middleware/redislock.middleware.ts +83 -0
  439. package/src/middleware/tx.middleware.ts +30 -0
  440. package/src/models/AsyncTaskModel.ts +85 -0
  441. package/src/models/RedisKeys.ts +16 -0
  442. package/src/models/SystemEntities.ts +125 -0
  443. package/src/models/SystemPerm.ts +105 -0
  444. package/src/models/SystemTables.ts +27 -0
  445. package/src/models/bizmodels.ts +123 -0
  446. package/src/models/contextLogger.ts +132 -0
  447. package/src/models/devops.ts +17 -0
  448. package/src/models/userSession.ts +217 -0
  449. package/src/schedule/anonymousContext.ts +73 -0
  450. package/src/schedule/index.ts +12 -0
  451. package/src/schedule/runSchedule.ts +82 -0
  452. package/src/schedule/scheduleNames.ts +21 -0
  453. package/src/service/AuthService.ts +284 -0
  454. package/src/service/EnumInfoService.ts +130 -0
  455. package/src/service/FileCenterService.ts +395 -0
  456. package/src/service/SysConfigService.ts +37 -0
  457. package/src/service/UserAccountService.ts +107 -0
  458. package/src/service/UserSessionService.ts +161 -0
  459. package/src/service/VisitStatService.ts +166 -0
  460. package/src/service/WorkbenchService.ts +220 -0
  461. package/src/service/anyapi/AnyApiSandboxService.ts +121 -0
  462. package/src/service/anyapi/AnyApiService.ts +186 -0
  463. package/src/service/asyncTask/AsyncTaskRunnerService.ts +325 -0
  464. package/src/service/asyncTask/AsyncTaskService.ts +21 -0
  465. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  466. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
  467. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +159 -0
  468. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +159 -0
  469. package/src/service/base/ApiBaseService.ts +42 -0
  470. package/src/service/base/ApiRateLimiter.ts +59 -0
  471. package/src/service/base/BaseService.ts +100 -0
  472. package/src/service/base/RedisCacheService.ts +45 -0
  473. package/src/service/crudstd/CrudStdActionService.ts +27 -0
  474. package/src/service/crudstd/CrudStdConstant.ts +62 -0
  475. package/src/service/crudstd/CrudStdRelationService.ts +118 -0
  476. package/src/service/crudstd/CrudStdService.ts +420 -0
  477. package/src/service/curd/CrudProQuick.ts +172 -0
  478. package/src/service/curd/CurdMixByAccountService.ts +89 -0
  479. package/src/service/curd/CurdMixByDictService.ts +114 -0
  480. package/src/service/curd/CurdMixByLinkToCustomService.ts +219 -0
  481. package/src/service/curd/CurdMixBySysConfigService.ts +78 -0
  482. package/src/service/curd/CurdMixByWorkbenchService.ts +71 -0
  483. package/src/service/curd/CurdMixService.ts +97 -0
  484. package/src/service/curd/CurdMixUtils.ts +316 -0
  485. package/src/service/curd/CurdProService.ts +231 -0
  486. package/src/service/curd/fixCfgModel.ts +120 -0
  487. package/src/service/proxyapi/ProxyApiLoadService.ts +174 -0
  488. package/src/service/proxyapi/ProxyApiService.ts +298 -0
  489. package/src/service/proxyapi/ProxyApiUtils.ts +32 -0
  490. package/src/service/proxyapi/RouteHandler.ts +8 -0
  491. package/src/service/proxyapi/RouteTrie.ts +74 -0
  492. package/src/service/proxyapi/WeightedRandom.ts +37 -0
  493. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -0
  494. package/src/views/404_app.html +31 -0
  495. package/src/views/404_workbench.html +34 -0
  496. package/src/views/static/favicon.ico +0 -0
  497. package/tsconfig.json +32 -32
@@ -0,0 +1,393 @@
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 orderByArr = orderBys.map(orderBy => {
242
+ return toSqlColumnName(orderBy.fieldName, sqlCfgModel) + ' ' + orderBy.orderType;
243
+ });
244
+ const sql = 'order by ' + orderByArr.join(',');
245
+ return new SqlSegArg(sql);
246
+ }
247
+
248
+ private generatePickResAs(req: RequestModel, world: string): SqlSegArg {
249
+ return new SqlSegArg(' ? ', [
250
+ {
251
+ ___GENERATE_GET_RES_ATTR___: world,
252
+ },
253
+ ]);
254
+ }
255
+
256
+ private generateGetAttr(req: RequestModel, word: string): SqlSegArg {
257
+ const attrName = MixinUtils.removeStringPrefix(word, '@@');
258
+
259
+ if (MixinUtils.isEmpty(attrName)) {
260
+ throw new CommonException(Exceptions.CFG_GET_ATTR_NAME_EMPTY, word);
261
+ }
262
+
263
+ const dataValue = req.getJsonObjectValue(attrName);
264
+
265
+ if (typeof dataValue === 'undefined' || !TypeUtils.isBasicType(dataValue)) {
266
+ throw new CommonException(Exceptions.CFG_GET_ATTR_VALUE_ERROR, word);
267
+ }
268
+
269
+ return new SqlSegArg(' ? ', [dataValue]);
270
+ }
271
+
272
+ private generateDataUpdate(req: RequestModel, sqlCfgModel: SqlCfgModel, dataName: string): SqlSegArg {
273
+ const data = req.getCondOrDataJsonObject(dataName);
274
+
275
+ if (MixinUtils.isEmpty(data)) {
276
+ throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_UPDATE, dataName);
277
+ }
278
+
279
+ const keys = Object.keys(data).sort();
280
+
281
+ const sqlList = [];
282
+ const argList = [];
283
+
284
+ for (let i = 0; i < keys.length; i++) {
285
+ const key = keys[i];
286
+ const arg = data[key];
287
+ if (sqlFuncUtils.isSqlFuncArg(arg)) {
288
+ const funcSQL = sqlFuncUtils.toFuncSQL(arg);
289
+ sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ' + funcSQL);
290
+ } else {
291
+ sqlList.push(toSqlColumnName(key, sqlCfgModel) + '= ?');
292
+ argList.push(arg);
293
+ }
294
+ }
295
+
296
+ const sql = sqlList.join(',');
297
+ return new SqlSegArg(sql, argList);
298
+ }
299
+
300
+ private generateDataAsInsertValues(req: RequestModel, dataName: string): SqlSegArg {
301
+ const data = req.getCondOrDataJsonObject(dataName);
302
+
303
+ if (MixinUtils.isEmpty(data)) {
304
+ throw new CommonException(Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_VALUES, dataName);
305
+ }
306
+
307
+ const keys = Object.keys(data).sort();
308
+
309
+ const sqlList = [];
310
+ const argList = [];
311
+
312
+ for (let i = 0; i < keys.length; i++) {
313
+ const key = keys[i];
314
+ const arg = data[key];
315
+
316
+ // 如 data: {xxxTime: {$byFunc:"NOW()"}}
317
+ if (sqlFuncUtils.isSqlFuncArg(arg)) {
318
+ const funcSQL = sqlFuncUtils.toFuncSQL(arg); // values( ? , ? , NOW() , ?)
319
+ sqlList.push(funcSQL);
320
+ } else {
321
+ sqlList.push('?');
322
+ argList.push(arg);
323
+ }
324
+ }
325
+
326
+ const sql = sqlList.join(','); // "?,?,?,?"
327
+ return new SqlSegArg(sql, argList);
328
+ }
329
+
330
+ private generateSqlJavaFunction(requestCfg: RequestCfgModel, tmpFuncName: string): SqlSegArg {
331
+ const exeCtx = this.getExecuteContext();
332
+
333
+ const functionCfg = requestCfg.functionCfg;
334
+
335
+ if (MixinUtils.isEmpty(functionCfg)) {
336
+ throw new CommonException(Exceptions.CFG_SQL_FUNCTION_EMPTY, tmpFuncName);
337
+ }
338
+
339
+ const tmpFunCfg = functionCfg[tmpFuncName];
340
+
341
+ if (ModelUtils.checkFuncCfgValid(tmpFunCfg)) {
342
+ throw new CommonException(Exceptions.CFG_VALIDATE_CUSTOM_FUNCTION_EMPTY, tmpFuncName);
343
+ }
344
+
345
+ const exeFunCtx = new FuncContext();
346
+
347
+ exeFunCtx.currentValue = null;
348
+ exeFunCtx.reqModel = exeCtx.getReqModel();
349
+ exeFunCtx.resModel = exeCtx.getResModel();
350
+
351
+ const dataValue = this.serviceHub.executeFuncCfg(tmpFunCfg, exeFunCtx);
352
+
353
+ return new SqlSegArg(' ? ', [dataValue]);
354
+ }
355
+
356
+ /**
357
+ * 不会返回空。
358
+ * @param sqlCfgModel
359
+ * @private
360
+ */
361
+ private async generateCfgColumns(sqlCfgModel: SqlCfgModel): Promise<string[]> {
362
+ const tableMeta = await this.serviceHub.getTableMeta(sqlCfgModel);
363
+
364
+ const tableColumns = tableMeta.tableColumns;
365
+ const cfgColumns = sqlCfgModel.columns || [];
366
+
367
+ // 没有配置: 全量
368
+ if (MixinUtils.isEmpty(cfgColumns)) {
369
+ return tableColumns;
370
+ }
371
+
372
+ // 黑名单:排除法
373
+ if (isAnyStartWithExclude(cfgColumns)) {
374
+ const excludeColumns = cfgColumns.filter(c => {
375
+ return c.startsWith('!');
376
+ });
377
+ const excludeColumnsSet = new Set(excludeColumns);
378
+ const result = [];
379
+ for (let i = 0; i < tableColumns.length; i++) {
380
+ const tableColumn = tableColumns[i];
381
+ if (!excludeColumnsSet.has('!' + tableColumn)) {
382
+ result.push(tableColumn);
383
+ }
384
+ }
385
+ return result;
386
+ }
387
+
388
+ // 白名单
389
+ return cfgColumns;
390
+ }
391
+ }
392
+
393
+ export { CrudProOriginToExecuteSql };
@@ -0,0 +1,107 @@
1
+ import * as _ from 'lodash';
2
+ import { ICurdProServiceHub } from '../models/ServiceHub';
3
+ import { ICrudProCfg, IExecuteUnsafeQueryCtx, ILogger, IPoolConnectionClient } from '../interfaces';
4
+ import { SqlCfgModel } from '../models/SqlCfgModel';
5
+ import { ExecuteContext } from '../models/ExecuteContext';
6
+ import { MixinUtils } from '../utils/MixinUtils';
7
+ import { TypeUtils } from '../utils/TypeUtils';
8
+ import { CompareUtils } from '../utils/CompareUtils';
9
+ import { DateTimeUtils } from '../utils/DateTimeUtils';
10
+ import { IExecuteContextFunc } from '../models/ExecuteContextFunc';
11
+ import { DEFAULT_MAX_LIMIT } from '../defaultConfigs';
12
+ import { SqlDbType } from '../models/keys';
13
+ import { replaceQuestionMarks } from '../utils/sqlConvert/convertPgSql';
14
+ import { replaceQuestionMarksForMssql } from '../utils/sqlConvert/convertMsSql';
15
+
16
+ function createBuildInExecuteFuncMap() {
17
+ return {
18
+ ...DateTimeUtils,
19
+ ...CompareUtils,
20
+ ...MixinUtils,
21
+ ...TypeUtils,
22
+ };
23
+ }
24
+
25
+ const buildInExecuteFuncMap = createBuildInExecuteFuncMap();
26
+
27
+ class CrudProServiceBase {
28
+ protected serviceHub: ICurdProServiceHub;
29
+
30
+ constructor(serviceHub: ICurdProServiceHub) {
31
+ this.serviceHub = serviceHub;
32
+ }
33
+
34
+ protected getExecuteContext(): ExecuteContext {
35
+ return this.serviceHub.getExecuteContext();
36
+ }
37
+
38
+ protected getContextFunc(): IExecuteContextFunc {
39
+ return this.getExecuteContext().contextFunc;
40
+ }
41
+
42
+ protected get logger(): ILogger {
43
+ return this.getExecuteContext().getLogger();
44
+ }
45
+
46
+ protected async getTxConnectionBySqlCfg(sqlCfgModel: SqlCfgModel): Promise<IPoolConnectionClient> {
47
+ const executeContext = this.getExecuteContext();
48
+ const transaction = executeContext.getTransaction();
49
+ const contextFunc = this.getContextFunc();
50
+ const pool = await contextFunc.getConnectionPool(sqlCfgModel);
51
+ return transaction.getTxConnection(pool);
52
+ }
53
+
54
+ /**
55
+ * 不做任何检验,直接执行SQL,只能CrudPro内部使用,不对外使用
56
+ * @param obj
57
+ * @param sql
58
+ * @param values
59
+ * @protected
60
+ */
61
+ protected async executeUnsafeQuery(obj: IExecuteUnsafeQueryCtx, sql: string, values?: any) {
62
+ const sqlCfgModel: any = {
63
+ sqlTable: obj.sqlTable,
64
+ sqlDatabase: obj.sqlDatabase,
65
+ sqlDbType: obj.sqlDbType,
66
+ columns: [],
67
+ columnsRelation: [],
68
+ maxLimit: DEFAULT_MAX_LIMIT,
69
+ resName: 'executeUnsafeQuery',
70
+ originSql: sql,
71
+ executeSql: sql,
72
+ executeSqlArgs: values,
73
+ crudType: null,
74
+ };
75
+
76
+
77
+ if (sqlCfgModel.sqlDbType === SqlDbType.postgres) {
78
+ const pgSql = replaceQuestionMarks(sqlCfgModel.executeSql);
79
+ sqlCfgModel.executeSql = pgSql;
80
+ } else if (sqlCfgModel.sqlDbType === SqlDbType.sqlserver) {
81
+ const mssql = replaceQuestionMarksForMssql(sqlCfgModel.executeSql);
82
+ sqlCfgModel.executeSql = mssql;
83
+ }
84
+
85
+ const connection = await this.getTxConnectionBySqlCfg(sqlCfgModel);
86
+ return await connection.query(sqlCfgModel.executeSql, values);
87
+ }
88
+
89
+ protected getContextCfg(): ICrudProCfg {
90
+ return this.getExecuteContext().getContextCfg();
91
+ }
92
+
93
+ protected getExecuteFunction(funcName: string): any {
94
+ const contextFunc = this.getContextFunc();
95
+ const functionMap = contextFunc.getFunctionMap();
96
+ if (functionMap) {
97
+ const func = _.get(functionMap, funcName);
98
+ if (typeof func === 'function') {
99
+ return func;
100
+ }
101
+ }
102
+ console.log('buildInExecuteFuncMap', Object.keys(buildInExecuteFuncMap));
103
+ return _.get(buildInExecuteFuncMap, funcName);
104
+ }
105
+ }
106
+
107
+ export { CrudProServiceBase };
@@ -0,0 +1,86 @@
1
+ import { CrudProServiceBase } from './CrudProServiceBase';
2
+ import { SqlCfgModel } from '../models/SqlCfgModel';
3
+ import { IExecuteUnsafeQueryCtx, ITableMeta } from '../interfaces';
4
+ import { SqlDbType } from '../models/keys';
5
+ import { pickAndConvertRowsByMix } from '../utils/sqlConvert/convertMix';
6
+
7
+ class CrudProTableMetaCache {
8
+ private cacheMap: Record<string, ITableMeta> = {};
9
+ private getCacheKey(sqlCfgModel: SqlCfgModel) {
10
+ return `${sqlCfgModel.sqlDatabase}:::${sqlCfgModel.sqlSchema}:::${sqlCfgModel.sqlTable}`;
11
+ }
12
+ public getMeta(sqlCfgModel: SqlCfgModel) {
13
+ const cacheKey = this.getCacheKey(sqlCfgModel);
14
+ const obj = this.cacheMap[cacheKey];
15
+ if (obj && obj.expiredTime < Date.now()) {
16
+ return obj;
17
+ }
18
+ return null;
19
+ }
20
+
21
+ public setMeta(sqlCfgModel: SqlCfgModel, metaObj: ITableMeta) {
22
+ const cacheKey = this.getCacheKey(sqlCfgModel);
23
+ this.cacheMap[cacheKey] = metaObj;
24
+ }
25
+ }
26
+
27
+ const metaCache = new CrudProTableMetaCache();
28
+
29
+ class CrudProTableMetaService extends CrudProServiceBase {
30
+ async getTableMeta(sqlCfgModel: SqlCfgModel): Promise<ITableMeta> {
31
+ let obj = metaCache.getMeta(sqlCfgModel);
32
+ if (!obj) {
33
+ obj = await this.loadTableMeta(sqlCfgModel);
34
+ metaCache.setMeta(sqlCfgModel, obj);
35
+ }
36
+ return obj;
37
+ }
38
+
39
+ private async loadTableMeta(sqlCfgModel: SqlCfgModel): Promise<ITableMeta> {
40
+ const { tableMetaCacheTime } = this.getContextCfg();
41
+
42
+ const obj = {
43
+ expiredTime: Date.now() + tableMetaCacheTime || 1000 * 3600 * 24 * 365,
44
+ tableColumns: [],
45
+ };
46
+
47
+ const baseInfo: IExecuteUnsafeQueryCtx = {
48
+ sqlTable: sqlCfgModel.sqlTable,
49
+ sqlDatabase: sqlCfgModel.sqlDatabase,
50
+ sqlDbType: sqlCfgModel.sqlDbType,
51
+ };
52
+
53
+ obj.tableColumns = await this.loadTableColumnInfo(baseInfo);
54
+
55
+ return obj;
56
+ }
57
+
58
+ private async loadTableColumnInfo(baseInfo: IExecuteUnsafeQueryCtx): Promise<string[]> {
59
+ if (baseInfo.sqlDbType === SqlDbType.mysql) {
60
+ const queryRes = await this.executeUnsafeQuery(baseInfo, 'describe ' + baseInfo.sqlTable);
61
+ const tableDescribe = pickAndConvertRowsByMix(queryRes, baseInfo.sqlDbType);
62
+ const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
63
+ return tableDescribe2.map(fieldObj => {
64
+ return fieldObj['Field'];
65
+ });
66
+ } else if (baseInfo.sqlDbType === SqlDbType.postgres) {
67
+ const schemaname = 'public';
68
+ const columnArraySql = `
69
+ SELECT
70
+ *
71
+ FROM information_schema.columns
72
+ WHERE table_schema = '${schemaname}' and table_name = '${baseInfo.sqlTable}'
73
+ ORDER BY ordinal_position;
74
+ `.trim();
75
+ const queryRes = await this.executeUnsafeQuery(baseInfo, columnArraySql);
76
+ const tableDescribe = pickAndConvertRowsByMix(queryRes, baseInfo.sqlDbType);
77
+ return tableDescribe.map(fieldObj => {
78
+ return fieldObj['column_name'];
79
+ });
80
+ }
81
+
82
+ throw new Error('暂不支持的数据库类型:' + baseInfo.sqlDbType);
83
+ }
84
+ }
85
+
86
+ export { CrudProTableMetaService };
@@ -0,0 +1,92 @@
1
+ import { IFuncCfgModel, IRequestCfgModel, ITableMeta } from '../interfaces';
2
+ import { RequestModel } from '../models/RequestModel';
3
+ import { CrudProFieldValidateService } from './CrudProFieldValidateService';
4
+ import { CrudProFieldUpdateService } from './CrudProFieldUpdateService';
5
+ import { CrudProCachedCfgService } from './CrudProCachedCfgService';
6
+ import { CrudProExecuteSqlService } from './CrudProExecuteSqlService';
7
+ import { CrudProGenSqlService } from './CrudProGenSqlService';
8
+ import { ExecuteContext } from '../models/ExecuteContext';
9
+ import { CrudProOriginToExecuteSql } from './CrudProOriginToExecuteSql';
10
+ import { SqlCfgModel } from '../models/SqlCfgModel';
11
+ import { RequestCfgModel } from '../models/RequestCfgModel';
12
+ import { ICurdProServiceHub } from '../models/ServiceHub';
13
+ import { FuncContext } from '../models/FuncContext';
14
+ import { CrudProExecuteFuncService } from './CrudProExecuteFuncService';
15
+ import { CrudProTableMetaService } from './CrudProTableMetaService';
16
+
17
+ class CurdProServiceHub implements ICurdProServiceHub {
18
+ private readonly executeContext: ExecuteContext;
19
+
20
+ private readonly fieldValidateService: CrudProFieldValidateService;
21
+ private readonly fieldUpdateService: CrudProFieldUpdateService;
22
+ private readonly cachedCfgService: CrudProCachedCfgService;
23
+ private readonly executeSqlService: CrudProExecuteSqlService;
24
+ private readonly genSqlService: CrudProGenSqlService;
25
+ private readonly originToExecuteSql: CrudProOriginToExecuteSql;
26
+ private readonly executeFuncService: CrudProExecuteFuncService;
27
+ private readonly tableMetaService: CrudProTableMetaService;
28
+
29
+ constructor(executeContext: ExecuteContext) {
30
+ this.executeContext = executeContext;
31
+ this.fieldValidateService = new CrudProFieldValidateService(this);
32
+ this.fieldUpdateService = new CrudProFieldUpdateService(this);
33
+ this.cachedCfgService = new CrudProCachedCfgService(this);
34
+ this.executeSqlService = new CrudProExecuteSqlService(this);
35
+ this.genSqlService = new CrudProGenSqlService(this);
36
+ this.originToExecuteSql = new CrudProOriginToExecuteSql(this);
37
+ this.executeFuncService = new CrudProExecuteFuncService(this);
38
+ this.tableMetaService = new CrudProTableMetaService(this);
39
+ }
40
+
41
+ getExecuteContext(): ExecuteContext {
42
+ return this.executeContext;
43
+ }
44
+
45
+ validateByAllow(cfgModel: RequestCfgModel, reqModel: RequestModel) {
46
+ return this.fieldValidateService.validateByAllow(cfgModel, reqModel);
47
+ }
48
+
49
+ validateByReject(cfgModel: RequestCfgModel, reqModel: RequestModel) {
50
+ return this.fieldValidateService.validateByReject(cfgModel, reqModel);
51
+ }
52
+
53
+ validateByCfg(cfgModel: RequestCfgModel, reqModel: RequestModel) {
54
+ return this.fieldValidateService.validateByCfg(cfgModel, reqModel);
55
+ }
56
+
57
+ async validateByAuthCfg(cfgModel: RequestCfgModel, reqModel: RequestModel): Promise<any> {
58
+ const contextFunc = this.executeContext.contextFunc;
59
+ if (contextFunc && contextFunc.validateByAuthCfg) {
60
+ return contextFunc.validateByAuthCfg(cfgModel, reqModel);
61
+ }
62
+ }
63
+
64
+ updateByCfg(cfgModel: RequestCfgModel, reqModel: RequestModel) {
65
+ return this.fieldUpdateService.updateByCfg(cfgModel, reqModel);
66
+ }
67
+ async getCachedCfgByMethod(method: string, isEnableCache: boolean): Promise<IRequestCfgModel> {
68
+ return this.cachedCfgService.getCachedCfgByMethod(method, isEnableCache);
69
+ }
70
+
71
+ async generateSQLList(): Promise<void> {
72
+ return this.genSqlService.generateSQLList();
73
+ }
74
+
75
+ async executeSqlCfgModels(): Promise<void> {
76
+ return this.executeSqlService.executeSqlCfgModels();
77
+ }
78
+
79
+ async convertOriginToExecuteSql(sqlCfgModel: SqlCfgModel): Promise<void> {
80
+ return this.originToExecuteSql.convertOriginToExecuteSql(sqlCfgModel);
81
+ }
82
+
83
+ executeFuncCfg(funCfg: IFuncCfgModel, funcContext: FuncContext): any {
84
+ return this.executeFuncService.executeFuncCfg(funCfg, funcContext);
85
+ }
86
+
87
+ async getTableMeta(sqlCfgModel: SqlCfgModel): Promise<ITableMeta> {
88
+ return await this.tableMetaService.getTableMeta(sqlCfgModel);
89
+ }
90
+ }
91
+
92
+ export { CurdProServiceHub };