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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (530) hide show
  1. package/.eslintrc.json +14 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +8 -1
  4. package/dist/config/config.default.d.ts +3 -3
  5. package/dist/config/config.default.js +171 -185
  6. package/dist/config/seed/aeskey.txt +1 -1
  7. package/dist/config/utils.d.ts +1 -1
  8. package/dist/config/utils.js +23 -23
  9. package/dist/configuration.d.ts +7 -6
  10. package/dist/configuration.js +113 -89
  11. package/dist/controller/base/BaseApiController.d.ts +42 -31
  12. package/dist/controller/base/BaseApiController.js +189 -141
  13. package/dist/controller/gateway/AnyApiGatewayController.d.ts +13 -13
  14. package/dist/controller/gateway/AnyApiGatewayController.js +55 -55
  15. package/dist/controller/gateway/AsyncTaskController.d.ts +20 -0
  16. package/dist/controller/gateway/AsyncTaskController.js +181 -0
  17. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
  18. package/dist/controller/gateway/CrudMtdGatewayController.js +122 -116
  19. package/dist/controller/gateway/CrudStdGatewayController.d.ts +39 -38
  20. package/dist/controller/gateway/CrudStdGatewayController.js +149 -137
  21. package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
  22. package/dist/controller/gateway/DocGatewayController.js +179 -179
  23. package/dist/controller/gateway/FileController.d.ts +32 -25
  24. package/dist/controller/gateway/FileController.js +160 -129
  25. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
  26. package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
  27. package/dist/controller/gateway/PublicApiController.d.ts +33 -27
  28. package/dist/controller/gateway/PublicApiController.js +201 -167
  29. package/dist/controller/gateway/StaticController.d.ts +23 -24
  30. package/dist/controller/gateway/StaticController.js +286 -285
  31. package/dist/controller/helpers.controller.d.ts +39 -39
  32. package/dist/controller/helpers.controller.js +188 -188
  33. package/dist/controller/home.controller.d.ts +9 -9
  34. package/dist/controller/home.controller.js +72 -71
  35. package/dist/controller/manage/AnyApiMangeApi.d.ts +10 -10
  36. package/dist/controller/manage/AnyApiMangeApi.js +98 -98
  37. package/dist/controller/manage/AppLogMangeApi.d.ts +10 -10
  38. package/dist/controller/manage/AppLogMangeApi.js +88 -88
  39. package/dist/controller/manage/AppMangeApi.d.ts +12 -10
  40. package/dist/controller/manage/AppMangeApi.js +101 -88
  41. package/dist/controller/manage/AppPageMangeApi.d.ts +10 -10
  42. package/dist/controller/manage/AppPageMangeApi.js +87 -87
  43. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +10 -10
  44. package/dist/controller/manage/AppSchemaHistoryApi.js +83 -83
  45. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +10 -10
  46. package/dist/controller/manage/CrudMethodsMangeApi.js +84 -84
  47. package/dist/controller/manage/CrudStandardDesignApi.d.ts +46 -38
  48. package/dist/controller/manage/CrudStandardDesignApi.js +395 -354
  49. package/dist/controller/manage/DataDictManageApi.d.ts +15 -15
  50. package/dist/controller/manage/DataDictManageApi.js +133 -133
  51. package/dist/controller/manage/DeployManageApi.d.ts +19 -19
  52. package/dist/controller/manage/DeployManageApi.js +180 -178
  53. package/dist/controller/manage/DocLibManageApi.d.ts +10 -10
  54. package/dist/controller/manage/DocLibManageApi.js +104 -104
  55. package/dist/controller/manage/DocManageApi.d.ts +11 -11
  56. package/dist/controller/manage/DocManageApi.js +130 -130
  57. package/dist/controller/manage/FileManageApi.d.ts +13 -13
  58. package/dist/controller/manage/FileManageApi.js +77 -77
  59. package/dist/controller/manage/LowCodeTplManageApi.d.ts +13 -13
  60. package/dist/controller/manage/LowCodeTplManageApi.js +86 -86
  61. package/dist/controller/manage/MenuManageApi.d.ts +10 -10
  62. package/dist/controller/manage/MenuManageApi.js +93 -93
  63. package/dist/controller/manage/ProxyApiMangeApi.d.ts +10 -10
  64. package/dist/controller/manage/ProxyApiMangeApi.js +87 -87
  65. package/dist/controller/manage/SuperAdminManageApi.d.ts +24 -24
  66. package/dist/controller/manage/SuperAdminManageApi.js +153 -153
  67. package/dist/controller/manage/SysConfigMangeApi.d.ts +12 -11
  68. package/dist/controller/manage/SysConfigMangeApi.js +133 -126
  69. package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
  70. package/dist/controller/manage/SystemInfoManageApi.js +72 -66
  71. package/dist/controller/manage/UserAccountManageApi.d.ts +16 -14
  72. package/dist/controller/manage/UserAccountManageApi.js +153 -124
  73. package/dist/controller/manage/WorkbenchMangeApi.d.ts +11 -11
  74. package/dist/controller/manage/WorkbenchMangeApi.js +103 -103
  75. package/dist/controller/myinfo/AuthController.d.ts +33 -37
  76. package/dist/controller/myinfo/AuthController.js +136 -189
  77. package/dist/controller/myinfo/MyInfoController.d.ts +13 -13
  78. package/dist/controller/myinfo/MyInfoController.js +51 -51
  79. package/dist/controller/render/AppRenderController.d.ts +12 -11
  80. package/dist/controller/render/AppRenderController.js +87 -87
  81. package/dist/controller/test.controller.d.ts +8 -8
  82. package/dist/controller/test.controller.js +51 -51
  83. package/dist/filter/default.filter.d.ts +7 -7
  84. package/dist/filter/default.filter.js +23 -23
  85. package/dist/filter/notfound.filter.d.ts +5 -5
  86. package/dist/filter/notfound.filter.js +20 -20
  87. package/dist/index.d.ts +104 -94
  88. package/dist/index.js +122 -112
  89. package/dist/interface.d.ts +29 -27
  90. package/dist/interface.js +3 -3
  91. package/dist/libs/crud-pro/CrudPro.d.ts +37 -36
  92. package/dist/libs/crud-pro/CrudPro.js +136 -131
  93. package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
  94. package/dist/libs/crud-pro/defaultConfigs.js +15 -13
  95. package/dist/libs/crud-pro/exceptions.d.ts +106 -104
  96. package/dist/libs/crud-pro/exceptions.js +119 -117
  97. package/dist/libs/crud-pro/interfaces.d.ts +166 -157
  98. package/dist/libs/crud-pro/interfaces.js +12 -12
  99. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +50 -42
  100. package/dist/libs/crud-pro/models/ExecuteContext.js +87 -79
  101. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -31
  102. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -64
  103. package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
  104. package/dist/libs/crud-pro/models/FuncContext.js +6 -6
  105. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
  106. package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
  107. package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
  108. package/dist/libs/crud-pro/models/RequestModel.js +113 -113
  109. package/dist/libs/crud-pro/models/ResModel.d.ts +20 -0
  110. package/dist/libs/crud-pro/models/ResModel.js +2 -0
  111. package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
  112. package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
  113. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +23 -22
  114. package/dist/libs/crud-pro/models/SqlCfgModel.js +40 -40
  115. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +6 -6
  116. package/dist/libs/crud-pro/models/SqlSegArg.js +12 -12
  117. package/dist/libs/crud-pro/models/Transaction.d.ts +30 -29
  118. package/dist/libs/crud-pro/models/Transaction.js +74 -67
  119. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +28 -28
  120. package/dist/libs/crud-pro/models/TransactionMySQL.js +76 -76
  121. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +28 -28
  122. package/dist/libs/crud-pro/models/TransactionPostgres.js +85 -85
  123. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +34 -34
  124. package/dist/libs/crud-pro/models/TransactionSqlServer.js +92 -92
  125. package/dist/libs/crud-pro/models/keys.d.ts +110 -106
  126. package/dist/libs/crud-pro/models/keys.js +154 -149
  127. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -10
  128. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -61
  129. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
  130. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +125 -112
  131. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
  132. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -227
  133. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +9 -9
  134. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +51 -51
  135. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +13 -13
  136. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +148 -148
  137. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +24 -24
  138. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +355 -342
  139. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
  140. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -174
  141. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
  142. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +339 -333
  143. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -28
  144. package/dist/libs/crud-pro/services/CrudProServiceBase.js +88 -78
  145. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -8
  146. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +78 -53
  147. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +32 -32
  148. package/dist/libs/crud-pro/services/CurdProServiceHub.js +64 -64
  149. package/dist/libs/crud-pro/sql.txt +120 -120
  150. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +9 -9
  151. package/dist/libs/crud-pro/utils/CompareUtils.js +25 -25
  152. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +9 -9
  153. package/dist/libs/crud-pro/utils/DatabaseName.js +50 -29
  154. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +7 -7
  155. package/dist/libs/crud-pro/utils/DateTimeUtils.js +21 -21
  156. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +19 -19
  157. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +47 -47
  158. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +5 -5
  159. package/dist/libs/crud-pro/utils/MessageParseUtils.js +33 -33
  160. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +39 -39
  161. package/dist/libs/crud-pro/utils/MixinUtils.js +255 -255
  162. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +11 -11
  163. package/dist/libs/crud-pro/utils/ModelUtils.js +54 -49
  164. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +11 -11
  165. package/dist/libs/crud-pro/utils/MultiKeyMap.js +63 -63
  166. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +5 -5
  167. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +29 -29
  168. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +40 -40
  169. package/dist/libs/crud-pro/utils/TypeUtils.js +166 -166
  170. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +3 -3
  171. package/dist/libs/crud-pro/utils/ValidateUtils.js +165 -165
  172. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +3 -3
  173. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +19 -19
  174. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +3 -3
  175. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +20 -20
  176. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +3 -3
  177. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +20 -20
  178. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +4 -4
  179. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +35 -21
  180. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -0
  181. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -0
  182. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +2 -2
  183. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +14 -11
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +14 -11
  186. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +2 -2
  187. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +128 -128
  188. package/dist/libs/global-config/global-config.d.ts +69 -19
  189. package/dist/libs/global-config/global-config.js +36 -25
  190. package/dist/libs/utils/AsymmetricCrypto.d.ts +76 -0
  191. package/dist/libs/utils/AsymmetricCrypto.js +261 -0
  192. package/dist/libs/utils/base64.d.ts +9 -0
  193. package/dist/libs/utils/base64.js +42 -0
  194. package/dist/libs/utils/common-dto.d.ts +18 -18
  195. package/dist/libs/utils/common-dto.js +40 -40
  196. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  197. package/dist/libs/utils/crypto-utils.js +46 -46
  198. package/dist/libs/utils/errorToString.d.ts +2 -0
  199. package/dist/libs/utils/errorToString.js +57 -0
  200. package/dist/libs/utils/fatcms-request.d.ts +30 -30
  201. package/dist/libs/utils/fatcms-request.js +104 -104
  202. package/dist/libs/utils/format-url.d.ts +2 -0
  203. package/dist/libs/utils/format-url.js +13 -0
  204. package/dist/libs/utils/functions.d.ts +5 -4
  205. package/dist/libs/utils/functions.js +72 -63
  206. package/dist/libs/utils/ordernum-utils.d.ts +2 -2
  207. package/dist/libs/utils/ordernum-utils.js +13 -13
  208. package/dist/libs/utils/parseConfig.d.ts +8 -7
  209. package/dist/libs/utils/parseConfig.js +47 -44
  210. package/dist/libs/utils/parseCreateSql.d.ts +10 -5
  211. package/dist/libs/utils/parseCreateSql.js +87 -86
  212. package/dist/libs/utils/render-utils.d.ts +37 -28
  213. package/dist/libs/utils/render-utils.js +154 -135
  214. package/dist/middleware/forbidden.middleware.d.ts +10 -10
  215. package/dist/middleware/forbidden.middleware.js +54 -70
  216. package/dist/middleware/global.middleware.d.ts +10 -10
  217. package/dist/middleware/global.middleware.js +273 -246
  218. package/dist/middleware/permission.middleware.d.ts +18 -18
  219. package/dist/middleware/permission.middleware.js +74 -74
  220. package/dist/middleware/rediscache.middleware.d.ts +3 -0
  221. package/dist/middleware/rediscache.middleware.js +77 -0
  222. package/dist/middleware/redislock.middleware.d.ts +7 -0
  223. package/dist/middleware/redislock.middleware.js +72 -0
  224. package/dist/middleware/tx.middleware.d.ts +9 -9
  225. package/dist/middleware/tx.middleware.js +40 -40
  226. package/dist/models/AsyncTaskModel.d.ts +74 -0
  227. package/dist/models/AsyncTaskModel.js +31 -0
  228. package/dist/models/RedisKeys.d.ts +15 -0
  229. package/dist/models/RedisKeys.js +18 -0
  230. package/dist/models/SystemEntities.d.ts +117 -98
  231. package/dist/models/SystemEntities.js +17 -2
  232. package/dist/models/SystemPerm.d.ts +95 -95
  233. package/dist/models/SystemPerm.js +100 -100
  234. package/dist/models/SystemTables.d.ts +25 -24
  235. package/dist/models/SystemTables.js +28 -27
  236. package/dist/models/WorkbenchInfoTools.d.ts +7 -0
  237. package/dist/models/WorkbenchInfoTools.js +20 -0
  238. package/dist/models/bizmodels.d.ts +138 -69
  239. package/dist/models/bizmodels.js +61 -34
  240. package/dist/models/contextLogger.d.ts +27 -25
  241. package/dist/models/contextLogger.js +119 -112
  242. package/dist/models/devops.d.ts +12 -12
  243. package/dist/models/devops.js +19 -19
  244. package/dist/models/userSession.d.ts +64 -61
  245. package/dist/models/userSession.js +167 -165
  246. package/dist/schedule/anonymousContext.d.ts +14 -0
  247. package/dist/schedule/anonymousContext.js +61 -0
  248. package/dist/schedule/index.d.ts +4 -3
  249. package/dist/schedule/index.js +10 -69
  250. package/dist/schedule/runSchedule.d.ts +12 -0
  251. package/dist/schedule/runSchedule.js +68 -0
  252. package/dist/schedule/scheduleNames.d.ts +13 -0
  253. package/dist/schedule/scheduleNames.js +17 -0
  254. package/dist/service/AuthService.d.ts +71 -70
  255. package/dist/service/AuthService.js +270 -251
  256. package/dist/service/EnumInfoService.d.ts +31 -30
  257. package/dist/service/EnumInfoService.js +120 -126
  258. package/dist/service/FileCenterService.d.ts +64 -43
  259. package/dist/service/FileCenterService.js +422 -351
  260. package/dist/service/SysAppService.d.ts +14 -0
  261. package/dist/service/SysAppService.js +96 -0
  262. package/dist/service/SysConfigService.d.ts +10 -7
  263. package/dist/service/SysConfigService.js +64 -47
  264. package/dist/service/UserAccountService.d.ts +23 -23
  265. package/dist/service/UserAccountService.js +107 -107
  266. package/dist/service/UserSessionService.d.ts +43 -16
  267. package/dist/service/UserSessionService.js +163 -85
  268. package/dist/service/VisitStatService.d.ts +14 -14
  269. package/dist/service/VisitStatService.js +158 -167
  270. package/dist/service/WorkbenchService.d.ts +59 -20
  271. package/dist/service/WorkbenchService.js +249 -155
  272. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  273. package/dist/service/anyapi/AnyApiSandboxService.js +122 -122
  274. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  275. package/dist/service/anyapi/AnyApiService.js +181 -181
  276. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -0
  277. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -0
  278. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -0
  279. package/dist/service/asyncTask/AsyncTaskService.js +34 -0
  280. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
  281. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
  282. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
  283. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -0
  284. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
  285. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -0
  286. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
  287. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -0
  288. package/dist/service/base/ApiBaseService.d.ts +15 -15
  289. package/dist/service/base/ApiBaseService.js +50 -50
  290. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  291. package/dist/service/base/ApiRateLimiter.js +51 -51
  292. package/dist/service/base/BaseService.d.ts +41 -29
  293. package/dist/service/base/BaseService.js +101 -79
  294. package/dist/service/base/cache/CacheServiceFactory.d.ts +23 -0
  295. package/dist/service/base/cache/CacheServiceFactory.js +83 -0
  296. package/dist/service/base/cache/CtxCache.d.ts +18 -0
  297. package/dist/service/base/cache/CtxCache.js +37 -0
  298. package/dist/service/base/cache/DiskCache.d.ts +19 -0
  299. package/dist/service/base/cache/DiskCache.js +74 -0
  300. package/dist/service/base/cache/MemoryCache.d.ts +12 -0
  301. package/dist/service/base/cache/MemoryCache.js +58 -0
  302. package/dist/service/base/cache/NoneCache.d.ts +10 -0
  303. package/dist/service/base/cache/NoneCache.js +19 -0
  304. package/dist/service/base/cache/RedisCache.d.ts +14 -0
  305. package/dist/service/base/cache/RedisCache.js +31 -0
  306. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  307. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  308. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  309. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  310. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  311. package/dist/service/crudstd/CrudStdRelationService.js +121 -85
  312. package/dist/service/crudstd/CrudStdService.d.ts +60 -50
  313. package/dist/service/crudstd/CrudStdService.js +376 -186
  314. package/dist/service/curd/CrudProQuick.d.ts +50 -0
  315. package/dist/service/curd/CrudProQuick.js +163 -0
  316. package/dist/service/curd/CurdMixByAccountService.d.ts +13 -9
  317. package/dist/service/curd/CurdMixByAccountService.js +151 -89
  318. package/dist/service/curd/CurdMixByDictService.d.ts +12 -13
  319. package/dist/service/curd/CurdMixByDictService.js +114 -113
  320. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +30 -22
  321. package/dist/service/curd/CurdMixByLinkToCustomService.js +202 -154
  322. package/dist/service/curd/CurdMixBySysConfigService.d.ts +13 -9
  323. package/dist/service/curd/CurdMixBySysConfigService.js +116 -80
  324. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +11 -10
  325. package/dist/service/curd/CurdMixByWorkbenchService.js +80 -78
  326. package/dist/service/curd/CurdMixService.d.ts +28 -17
  327. package/dist/service/curd/CurdMixService.js +100 -76
  328. package/dist/service/curd/CurdMixUtils.d.ts +57 -28
  329. package/dist/service/curd/CurdMixUtils.js +331 -201
  330. package/dist/service/curd/CurdProService.d.ts +32 -39
  331. package/dist/service/curd/CurdProService.js +212 -322
  332. package/dist/service/curd/fixCfgModel.d.ts +3 -0
  333. package/dist/service/curd/fixCfgModel.js +104 -0
  334. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  335. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  336. package/dist/service/proxyapi/ProxyApiService.d.ts +61 -60
  337. package/dist/service/proxyapi/ProxyApiService.js +294 -260
  338. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  339. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  340. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  341. package/dist/service/proxyapi/RouteHandler.js +9 -9
  342. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  343. package/dist/service/proxyapi/RouteTrie.js +63 -63
  344. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  345. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  346. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  347. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  348. package/dist/views/404_app.html +31 -31
  349. package/dist/views/404_workbench.html +34 -34
  350. package/index.d.ts +10 -10
  351. package/package.json +87 -75
  352. package/src/config/config.default.ts +191 -203
  353. package/src/config/seed/aeskey.txt +1 -1
  354. package/src/config/utils.ts +22 -23
  355. package/src/configuration.ts +109 -83
  356. package/src/controller/base/BaseApiController.ts +209 -145
  357. package/src/controller/gateway/AnyApiGatewayController.ts +33 -33
  358. package/src/controller/gateway/AsyncTaskController.ts +157 -0
  359. package/src/controller/gateway/CrudMtdGatewayController.ts +116 -107
  360. package/src/controller/gateway/CrudStdGatewayController.ts +113 -101
  361. package/src/controller/gateway/DocGatewayController.ts +173 -173
  362. package/src/controller/gateway/FileController.ts +138 -110
  363. package/src/controller/gateway/ProxyApiGatewayController.ts +47 -47
  364. package/src/controller/gateway/PublicApiController.ts +179 -145
  365. package/src/controller/gateway/StaticController.ts +296 -328
  366. package/src/controller/helpers.controller.ts +161 -161
  367. package/src/controller/home.controller.ts +66 -69
  368. package/src/controller/manage/AnyApiMangeApi.ts +66 -66
  369. package/src/controller/manage/AppLogMangeApi.ts +53 -53
  370. package/src/controller/manage/AppMangeApi.ts +66 -53
  371. package/src/controller/manage/AppPageMangeApi.ts +52 -52
  372. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -49
  373. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -49
  374. package/src/controller/manage/CrudStandardDesignApi.ts +406 -398
  375. package/src/controller/manage/DataDictManageApi.ts +78 -78
  376. package/src/controller/manage/DeployManageApi.ts +175 -182
  377. package/src/controller/manage/DocLibManageApi.ts +69 -69
  378. package/src/controller/manage/DocManageApi.ts +99 -99
  379. package/src/controller/manage/FileManageApi.ts +45 -45
  380. package/src/controller/manage/LowCodeTplManageApi.ts +52 -52
  381. package/src/controller/manage/MenuManageApi.ts +58 -63
  382. package/src/controller/manage/ProxyApiMangeApi.ts +52 -52
  383. package/src/controller/manage/SuperAdminManageApi.ts +139 -147
  384. package/src/controller/manage/SysConfigMangeApi.ts +103 -98
  385. package/src/controller/manage/SystemInfoManageApi.ts +53 -48
  386. package/src/controller/manage/UserAccountManageApi.ts +122 -88
  387. package/src/controller/manage/WorkbenchMangeApi.ts +72 -72
  388. package/src/controller/myinfo/AuthController.ts +108 -174
  389. package/src/controller/myinfo/MyInfoController.ts +32 -32
  390. package/src/controller/render/AppRenderController.ts +72 -79
  391. package/src/controller/test.controller.ts +37 -37
  392. package/src/filter/default.filter.ts +13 -13
  393. package/src/filter/notfound.filter.ts +10 -10
  394. package/src/index.ts +108 -99
  395. package/src/interface.ts +33 -31
  396. package/src/libs/crud-pro/CrudPro.ts +165 -158
  397. package/src/libs/crud-pro/defaultConfigs.ts +15 -13
  398. package/src/libs/crud-pro/exceptions.ts +126 -124
  399. package/src/libs/crud-pro/interfaces.ts +194 -183
  400. package/src/libs/crud-pro/models/ExecuteContext.ts +129 -111
  401. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +96 -86
  402. package/src/libs/crud-pro/models/FuncContext.ts +21 -21
  403. package/src/libs/crud-pro/models/RequestCfgModel.ts +141 -141
  404. package/src/libs/crud-pro/models/RequestModel.ts +141 -141
  405. package/src/libs/crud-pro/models/ResModel.ts +24 -0
  406. package/src/libs/crud-pro/models/ServiceHub.ts +32 -32
  407. package/src/libs/crud-pro/models/SqlCfgModel.ts +53 -52
  408. package/src/libs/crud-pro/models/SqlSegArg.ts +13 -13
  409. package/src/libs/crud-pro/models/Transaction.ts +81 -74
  410. package/src/libs/crud-pro/models/TransactionMySQL.ts +79 -79
  411. package/src/libs/crud-pro/models/TransactionPostgres.ts +91 -91
  412. package/src/libs/crud-pro/models/TransactionSqlServer.ts +102 -107
  413. package/src/libs/crud-pro/models/keys.ts +165 -159
  414. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +83 -75
  415. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +145 -128
  416. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +264 -279
  417. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +60 -60
  418. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +180 -180
  419. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +374 -373
  420. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +185 -202
  421. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +399 -397
  422. package/src/libs/crud-pro/services/CrudProServiceBase.ts +104 -98
  423. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -59
  424. package/src/libs/crud-pro/services/CurdProServiceHub.ts +92 -92
  425. package/src/libs/crud-pro/sql.txt +120 -120
  426. package/src/libs/crud-pro/utils/CompareUtils.ts +23 -23
  427. package/src/libs/crud-pro/utils/DatabaseName.ts +60 -40
  428. package/src/libs/crud-pro/utils/DateTimeUtils.ts +20 -20
  429. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +64 -64
  430. package/src/libs/crud-pro/utils/MessageParseUtils.ts +33 -33
  431. package/src/libs/crud-pro/utils/MixinUtils.ts +285 -285
  432. package/src/libs/crud-pro/utils/ModelUtils.ts +60 -55
  433. package/src/libs/crud-pro/utils/MultiKeyMap.ts +72 -72
  434. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +29 -29
  435. package/src/libs/crud-pro/utils/TypeUtils.ts +188 -188
  436. package/src/libs/crud-pro/utils/ValidateUtils.ts +165 -167
  437. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +20 -20
  438. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +22 -22
  439. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +22 -22
  440. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +39 -26
  441. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +24 -0
  442. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +13 -11
  443. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +14 -11
  444. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +127 -129
  445. package/src/libs/global-config/global-config.ts +108 -47
  446. package/src/libs/utils/AsymmetricCrypto.ts +310 -0
  447. package/src/libs/utils/base64.ts +40 -0
  448. package/src/libs/utils/common-dto.ts +52 -52
  449. package/src/libs/utils/crypto-utils.ts +50 -52
  450. package/src/libs/utils/errorToString.ts +61 -0
  451. package/src/libs/utils/fatcms-request.ts +103 -115
  452. package/src/libs/utils/format-url.ts +16 -0
  453. package/src/libs/utils/functions.ts +78 -67
  454. package/src/libs/utils/ordernum-utils.ts +14 -18
  455. package/src/libs/utils/parseConfig.ts +58 -62
  456. package/src/libs/utils/parseCreateSql.ts +91 -91
  457. package/src/libs/utils/render-utils.ts +216 -184
  458. package/src/middleware/forbidden.middleware.ts +52 -71
  459. package/src/middleware/global.middleware.ts +301 -278
  460. package/src/middleware/permission.middleware.ts +80 -81
  461. package/src/middleware/rediscache.middleware.ts +91 -0
  462. package/src/middleware/redislock.middleware.ts +83 -0
  463. package/src/middleware/tx.middleware.ts +30 -30
  464. package/src/models/AsyncTaskModel.ts +85 -0
  465. package/src/models/RedisKeys.ts +16 -0
  466. package/src/models/SystemEntities.ts +137 -115
  467. package/src/models/SystemPerm.ts +104 -105
  468. package/src/models/SystemTables.ts +26 -26
  469. package/src/models/WorkbenchInfoTools.ts +19 -0
  470. package/src/models/bizmodels.ts +170 -89
  471. package/src/models/contextLogger.ts +141 -132
  472. package/src/models/devops.ts +17 -17
  473. package/src/models/userSession.ts +221 -216
  474. package/src/schedule/anonymousContext.ts +75 -0
  475. package/src/schedule/index.ts +5 -73
  476. package/src/schedule/runSchedule.ts +74 -0
  477. package/src/schedule/scheduleNames.ts +15 -0
  478. package/src/service/AuthService.ts +299 -275
  479. package/src/service/EnumInfoService.ts +124 -134
  480. package/src/service/FileCenterService.ts +483 -400
  481. package/src/service/SysAppService.ts +88 -0
  482. package/src/service/SysConfigService.ts +51 -38
  483. package/src/service/UserAccountService.ts +107 -110
  484. package/src/service/UserSessionService.ts +163 -81
  485. package/src/service/VisitStatService.ts +166 -183
  486. package/src/service/WorkbenchService.ts +277 -165
  487. package/src/service/anyapi/AnyApiSandboxService.ts +121 -121
  488. package/src/service/anyapi/AnyApiService.ts +186 -189
  489. package/src/service/asyncTask/AsyncTaskRunnerService.ts +319 -0
  490. package/src/service/asyncTask/AsyncTaskService.ts +21 -0
  491. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  492. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
  493. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +159 -0
  494. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +158 -0
  495. package/src/service/base/ApiBaseService.ts +42 -42
  496. package/src/service/base/ApiRateLimiter.ts +59 -59
  497. package/src/service/base/BaseService.ts +95 -74
  498. package/src/service/base/cache/CacheServiceFactory.ts +86 -0
  499. package/src/service/base/cache/CtxCache.ts +45 -0
  500. package/src/service/base/cache/DiskCache.ts +82 -0
  501. package/src/service/base/cache/MemoryCache.ts +68 -0
  502. package/src/service/base/cache/NoneCache.ts +24 -0
  503. package/src/service/base/cache/RedisCache.ts +41 -0
  504. package/src/service/crudstd/CrudStdActionService.ts +27 -27
  505. package/src/service/crudstd/CrudStdConstant.ts +62 -62
  506. package/src/service/crudstd/CrudStdRelationService.ts +131 -78
  507. package/src/service/crudstd/CrudStdService.ts +458 -198
  508. package/src/service/curd/CrudProQuick.ts +189 -0
  509. package/src/service/curd/CurdMixByAccountService.ts +161 -88
  510. package/src/service/curd/CurdMixByDictService.ts +115 -119
  511. package/src/service/curd/CurdMixByLinkToCustomService.ts +221 -167
  512. package/src/service/curd/CurdMixBySysConfigService.ts +121 -83
  513. package/src/service/curd/CurdMixByWorkbenchService.ts +71 -72
  514. package/src/service/curd/CurdMixService.ts +97 -65
  515. package/src/service/curd/CurdMixUtils.ts +383 -248
  516. package/src/service/curd/CurdProService.ts +231 -379
  517. package/src/service/curd/fixCfgModel.ts +120 -0
  518. package/src/service/proxyapi/ProxyApiLoadService.ts +170 -173
  519. package/src/service/proxyapi/ProxyApiService.ts +298 -262
  520. package/src/service/proxyapi/ProxyApiUtils.ts +32 -32
  521. package/src/service/proxyapi/RouteHandler.ts +8 -8
  522. package/src/service/proxyapi/RouteTrie.ts +74 -74
  523. package/src/service/proxyapi/WeightedRandom.ts +37 -37
  524. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -44
  525. package/src/views/404_app.html +31 -31
  526. package/src/views/404_workbench.html +34 -34
  527. package/tsconfig.json +32 -0
  528. package/dist/service/base/RedisCacheService.d.ts +0 -13
  529. package/dist/service/base/RedisCacheService.js +0 -50
  530. package/src/service/base/RedisCacheService.ts +0 -38
@@ -1,159 +1,165 @@
1
- export enum SqlDbType {
2
- mysql = 'mysql',
3
- postgres = 'postgres',
4
- sqlserver = 'sqlserver', //微软 SQL Server
5
- }
6
-
7
- export enum KeysOfFunCtx {
8
- FUNC_CTX = '$',
9
- CURRENT_VALUE = '$current',
10
- VISITOR = 'visitor',
11
- VISITOR_ATTR = 'visitor.',
12
- REQUEST = 'req.',
13
- RESULT = 'res.',
14
- }
15
-
16
- //鉴权类型;free无需鉴权,login仅登录即可,byRoleCode校验角色,byFuncCode校验功能点
17
- export enum KeysOfAuthType {
18
- free = 'free', // 无需任何校验
19
- login = 'login', // 仅仅登录即可
20
- byRoleCode = 'byRoleCode', // 根据角色校验
21
- byFuncCode = 'byFuncCode', // 根据功能点校验
22
- }
23
-
24
- export enum KeysOfValidators {
25
- REQUIRED = 'required',
26
- BOOLEAN = 'boolean', // 布尔值类型
27
- OBJECT = 'object', // 普通对象类型类型
28
- ARRAY = 'array', // 数组
29
- ARRAY_STRING = 'array:string', // 数组
30
- ARRAY_NUMBER = 'array:number', // 数组
31
- STRING = 'string', // 字符串类型
32
- EMAIL = 'email',
33
- NAME = 'name', //必须以字母开头,只能包含:字母/数字/下划线
34
- PHONE_CN = 'phone:cn', // 中国手机号:11位
35
- INTEGER = 'integer', // long,int,short,bigInteger
36
- NUMBER = 'number', // long,int,short,float,double
37
- NUMERIC = 'numeric', //long,int,short,float,double或只包含数字的字符串
38
- MOMENT = 'moment:', // moment:YYYY-MM-DD HH:mm:ss 时间日期格式校验
39
- SCALE = 'scale:', // 判断参数是否位于这个区间:scale:[1,3] ; scale:(1,3) ; scale:(1,3] ;
40
- LENGTH = 'length:', // length:1,5 ; length >=1 and length <=5
41
- REG_EXP = 'regexp:', // regexp:[a-zA-Z-_.]
42
- ENUM = 'enum:', // enum : 1,2,3,4,5,6,aa,bb,cc :比较时用字符串比较
43
- }
44
-
45
- export enum KeyOfCrudTypes {
46
- SELECT = 'SELECT',
47
- UPDATE = 'UPDATE',
48
- INSERT = 'INSERT',
49
- DELETE = 'DELETE',
50
- NOT_CRUD = 'NOT_CRUD',
51
- EMPTY_SQL = 'EMPTY_SQL',
52
- SYS_QUERY = 'SYS_QUERY',
53
- }
54
-
55
- export enum KeysOfSimpleSQL {
56
- SIMPLE_QUERY = 'SIMPLE_QUERY', // select * from xx where @condition limit 100,
57
- SIMPLE_QUERY_ONE = 'SIMPLE_QUERY_ONE', //只查询一条 select * from xx where @condition limit 1,
58
- SIMPLE_QUERY_PAGE = 'SIMPLE_QUERY_PAGE', //分页查询 select * from xx where @condition limit 100 offset 100,
59
- SIMPLE_QUERY_COUNT = 'SIMPLE_QUERY_COUNT', //查询数量 select count(0) as totalCount from xx where @condition,
60
- SIMPLE_UPDATE = 'SIMPLE_UPDATE', // update xx set @data where @condition limit 1
61
- SIMPLE_INSERT = 'SIMPLE_INSERT', // insert into xx values @datas
62
- SIMPLE_DELETE = 'SIMPLE_DELETE', // delete from xx values where @condition limit 1
63
- SIMPLE_INSERT_ON_DUPLICATE_UPDATE = 'SIMPLE_INSERT_ON_DUPLICATE_UPDATE',
64
- SIMPLE_INSERT_OR_UPDATE = 'SIMPLE_INSERT_OR_UPDATE',
65
- CUSTOM = 'CUSTOM',
66
- }
67
-
68
- export enum KeysOfSqlResPicker {
69
- UPDATE_RESULT = 'UPDATE_RESULT', // update/insert/delete 产生影响的结果
70
- RESULT_FIRST_ROW = 'RESULT_FIRST_ROW', // $ResultSet[0], 只取第一行的数据返回。返回JSONObject
71
- RESULT_TOTAL_COUNT = 'RESULT_TOTAL_COUNT', // $ResultSet[0].total_count , 只取第一行的的total_count。返回long
72
- RESULT_ONE_VALUE = 'RESULT_ONE_VALUE', // $ResultSet[0].total_count , 只取第一行的的total_count。返回long
73
- }
74
-
75
- export const KeysOfCustomSQL = {
76
- SQL_COLUMNS: '@@columns',
77
- SQL_TABLE: '@@table', // 只有简单查询才能用得到
78
- SQL_OFFSET_LIMIT: '@@offsetLimit',
79
- SQL_ORDER_BYS: '@@orderBys',
80
-
81
- SQL_AS_WHERE: '@@asWhere:', // @@asWhere:condition , @@asWhere:condition_zhangsan
82
- SQL_AS_UPDATE: '@@asUpdate:', // @@asUpdate:data, @@asWhere:data_zhangsan
83
- SQL_AS_INSERT_KEYS: '@@asInsertKeys:', // @@asInsertKeys:data, @@asInsertKeys:data_zhangsan
84
- SQL_AS_INSERT_VALUES: '@@asInsertValues:', // @@asInsertValues:data, @@asInsertValues:data_zhangsan
85
-
86
- // 从Req中取值:单独取Data中的某个字段:获取单个值。
87
- SQL_GET_DATA_ATTR_START: '@@data', // // select * from fa_lang_faq where id = @@data.id
88
- SQL_GET_CONDITION_ATTR_START: '@@condition', // select * from fa_lang_faq where id = @@condition.id
89
-
90
- // 从Res中取值
91
- SQL_PICK_RES_AS_NUMBER: '@@pickResAsNumber:', // select * from fa_lang_faq where id = @@pickResAsNumber:rows[0].id
92
- SQL_PICK_RES_AS_STRING: '@@pickResAsString:', // select * from fa_lang_faq where lang_code = @@pickResAsString:row.lang_code
93
-
94
- // 使用java函数:获取单个值
95
- SQL_FUNCTION: '@@function:', // @@function:aaa
96
- };
97
-
98
- /**
99
- * 查询条件中允许出现的关键词
100
- * 与MongoDB的语法完全一致
101
- */
102
- export const KeysOfConditions = {
103
- $OR: '$or', //或
104
-
105
- $NE: '$ne', //不等于
106
- $LT: '$lt', //小于
107
- $LTE: '$lte', //小于或等于
108
- $GT: '$gt', //大于
109
- $GTE: '$gte', //大于或等于
110
- $IN: '$in', //in
111
- $NIN: '$nin', // not in
112
- $NOT_NULL: '$notNull', // is not null
113
- $NULL: '$null', // is null
114
- $RANGE: '$range', // between 1 and 2
115
- $LIKE: '$like', // A% 以A开头 {age:1, name:{"$like":"张"} }
116
- $NOT_LIKE: '$notLike', // A% 以A开头 {age:1, name:{"$notLike":"张"} }
117
-
118
- $LIKE_INCLUDE: '$likeInclude', // %A% 包含A {age:1, name:{"$like":"张"} }
119
- $NOT_LIKE_INCLUDE: '$notLikeInclude', // %A% 包含A {age:1, name:{"$notLike":"张"} }
120
-
121
- $MATCH: '$match', // 全文索引 {age:1, name:{"$match":"张"} }
122
- $MATCH_BOOL: '$matchBool', // 全文索引 {age:1, name:{"$matchBool":"张"} }
123
-
124
- COMPARE_KEYS: new Set<string>([]),
125
- ALL_KEYS: new Set<string>([]),
126
- };
127
-
128
- function initKeysOfConditions() {
129
- const addIgnoreCase = (keys: Set<string>, key: string) => {
130
- keys.add(key);
131
- keys.add(key.toUpperCase());
132
- keys.add(key.toLowerCase());
133
- };
134
-
135
- // 比较操作符, 支持忽略大小写
136
- KeysOfConditions.COMPARE_KEYS = new Set([]);
137
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NE);
138
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LT);
139
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LTE);
140
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$GT);
141
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$GTE);
142
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$IN);
143
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NIN);
144
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LIKE);
145
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LIKE_INCLUDE);
146
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NOT_LIKE);
147
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NOT_LIKE_INCLUDE);
148
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$MATCH);
149
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$MATCH_BOOL);
150
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$RANGE);
151
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NULL);
152
- addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NOT_NULL);
153
-
154
- // 所有操作符
155
- KeysOfConditions.ALL_KEYS = new Set([...KeysOfConditions.COMPARE_KEYS]);
156
- addIgnoreCase(KeysOfConditions.ALL_KEYS, KeysOfConditions.$OR);
157
- }
158
-
159
- initKeysOfConditions();
1
+ export enum SqlDbType {
2
+ mysql = 'mysql',
3
+ postgres = 'postgres',
4
+ sqlserver = 'sqlserver', //微软 SQL Server
5
+ }
6
+
7
+ export enum KeysOfFunCtx {
8
+ FUNC_CTX = '$',
9
+ CURRENT_VALUE = '$current',
10
+ VISITOR = 'visitor',
11
+ VISITOR_ATTR = 'visitor.',
12
+ REQUEST = 'req.',
13
+ RESULT = 'res.',
14
+ }
15
+
16
+ //鉴权类型;free无需鉴权,login仅登录即可,byRoleCode校验角色,byFuncCode校验功能点
17
+ export enum KeysOfAuthType {
18
+ free = 'free', // 无需任何校验
19
+ login = 'login', // 仅仅登录即可
20
+ byRoleCode = 'byRoleCode', // 根据角色校验
21
+ byFuncCode = 'byFuncCode', // 根据功能点校验
22
+ }
23
+
24
+ export enum KeysOfValidators {
25
+ REQUIRED = 'required',
26
+ BOOLEAN = 'boolean', // 布尔值类型
27
+ OBJECT = 'object', // 普通对象类型类型
28
+ ARRAY = 'array', // 数组
29
+ ARRAY_STRING = 'array:string', // 数组
30
+ ARRAY_NUMBER = 'array:number', // 数组
31
+ STRING = 'string', // 字符串类型
32
+ EMAIL = 'email',
33
+ NAME = 'name', //必须以字母开头,只能包含:字母/数字/下划线
34
+ PHONE_CN = 'phone:cn', // 中国手机号:11位
35
+ INTEGER = 'integer', // long,int,short,bigInteger
36
+ NUMBER = 'number', // long,int,short,float,double
37
+ NUMERIC = 'numeric', //long,int,short,float,double或只包含数字的字符串
38
+ MOMENT = 'moment:', // moment:YYYY-MM-DD HH:mm:ss 时间日期格式校验
39
+ SCALE = 'scale:', // 判断参数是否位于这个区间:scale:[1,3] ; scale:(1,3) ; scale:(1,3] ;
40
+ LENGTH = 'length:', // length:1,5 ; length >=1 and length <=5
41
+ REG_EXP = 'regexp:', // regexp:[a-zA-Z-_.]
42
+ ENUM = 'enum:', // enum : 1,2,3,4,5,6,aa,bb,cc :比较时用字符串比较
43
+ }
44
+
45
+ export enum KeyOfCrudTypes {
46
+ SELECT = 'SELECT',
47
+ UPDATE = 'UPDATE',
48
+ INSERT = 'INSERT',
49
+ DELETE = 'DELETE',
50
+ NOT_CRUD = 'NOT_CRUD',
51
+ EMPTY_SQL = 'EMPTY_SQL',
52
+ SYS_QUERY = 'SYS_QUERY',
53
+ }
54
+
55
+ export enum KeysOfSimpleSQL {
56
+ SIMPLE_QUERY = 'SIMPLE_QUERY', // select * from xx where @condition limit 100,
57
+ SIMPLE_QUERY_ONE = 'SIMPLE_QUERY_ONE', //只查询一条 select * from xx where @condition limit 1,
58
+ SIMPLE_QUERY_PAGE = 'SIMPLE_QUERY_PAGE', //分页查询 select * from xx where @condition limit 100 offset 100,
59
+ SIMPLE_QUERY_COUNT = 'SIMPLE_QUERY_COUNT', //查询数量 select count(0) as totalCount from xx where @condition,
60
+ SIMPLE_UPDATE = 'SIMPLE_UPDATE', // update xx set @data where @condition limit 1
61
+ SIMPLE_INSERT = 'SIMPLE_INSERT', // insert into xx values @datas
62
+ SIMPLE_DELETE = 'SIMPLE_DELETE', // delete from xx values where @condition limit 1
63
+ SIMPLE_INSERT_ON_DUPLICATE_UPDATE = 'SIMPLE_INSERT_ON_DUPLICATE_UPDATE',
64
+ SIMPLE_INSERT_OR_UPDATE = 'SIMPLE_INSERT_OR_UPDATE',
65
+ CUSTOM = 'CUSTOM',
66
+ }
67
+
68
+ export enum KeysOfSqlResPicker {
69
+ UPDATE_RESULT = 'UPDATE_RESULT', // update/insert/delete 产生影响的结果
70
+ RESULT_FIRST_ROW = 'RESULT_FIRST_ROW', // $ResultSet[0], 只取第一行的数据返回。返回JSONObject
71
+ RESULT_TOTAL_COUNT = 'RESULT_TOTAL_COUNT', // $ResultSet[0].total_count , 只取第一行的的total_count。返回long
72
+ RESULT_ONE_VALUE = 'RESULT_ONE_VALUE', // $ResultSet[0].total_count , 只取第一行的的total_count。返回long
73
+ }
74
+
75
+ export const KeysOfCustomSQL = {
76
+ SQL_COLUMNS: '@@columns',
77
+ SQL_TABLE: '@@table', // 只有简单查询才能用得到
78
+ SQL_OFFSET_LIMIT: '@@offsetLimit',
79
+ SQL_ORDER_BYS: '@@orderBys',
80
+
81
+ SQL_AS_WHERE: '@@asWhere:', // @@asWhere:condition , @@asWhere:condition_zhangsan
82
+ SQL_AS_UPDATE: '@@asUpdate:', // @@asUpdate:data, @@asWhere:data_zhangsan
83
+ SQL_AS_INSERT_KEYS: '@@asInsertKeys:', // @@asInsertKeys:data, @@asInsertKeys:data_zhangsan
84
+ SQL_AS_INSERT_VALUES: '@@asInsertValues:', // @@asInsertValues:data, @@asInsertValues:data_zhangsan
85
+
86
+ // 从Req中取值:单独取Data中的某个字段:获取单个值。
87
+ SQL_GET_DATA_ATTR_START: '@@data', // // select * from fa_lang_faq where id = @@data.id
88
+ SQL_GET_CONDITION_ATTR_START: '@@condition', // select * from fa_lang_faq where id = @@condition.id
89
+
90
+ // 从Res中取值
91
+ SQL_PICK_RES_AS_NUMBER: '@@pickResAsNumber:', // select * from fa_lang_faq where id = @@pickResAsNumber:rows[0].id
92
+ SQL_PICK_RES_AS_STRING: '@@pickResAsString:', // select * from fa_lang_faq where lang_code = @@pickResAsString:row.lang_code
93
+
94
+ // 使用java函数:获取单个值
95
+ SQL_FUNCTION: '@@function:', // @@function:aaa
96
+ };
97
+
98
+ /**
99
+ * 查询条件中允许出现的关键词
100
+ * 与MongoDB的语法完全一致
101
+ */
102
+ export const KeysOfConditions = {
103
+ $OR: '$or', //或
104
+
105
+ $NE: '$ne', //不等于
106
+ $LT: '$lt', //小于
107
+ $LTE: '$lte', //小于或等于
108
+ $GT: '$gt', //大于
109
+ $GTE: '$gte', //大于或等于
110
+ $IN: '$in', //in
111
+ $NIN: '$nin', // not in
112
+ $NOT_NULL: '$notNull', // is not null
113
+ $NULL: '$null', // is null
114
+ $RANGE: '$range', // between 1 and 2
115
+ $LIKE: '$like', //前缀匹配, A% 以A开头 {age:1, name:{"$like":"张"} }
116
+ $NOT_LIKE: '$notLike', // 前缀匹配 A% 以A开头 {age:1, name:{"$notLike":"张"} }
117
+
118
+ $LIKE_INCLUDE: '$likeInclude', // %A% 包含A {age:1, name:{"$like":"张"} }
119
+ $NOT_LIKE_INCLUDE: '$notLikeInclude', // %A% 包含A {age:1, name:{"$notLike":"张"} }
120
+
121
+ $MATCH: '$match', // MYSQL 全文索引 {age:1, name:{"$match":"张"} }
122
+ $MATCH_BOOL: '$matchBool', // MYSQL 全文索引 {age:1, name:{"$matchBool":"张"} }
123
+
124
+ /**
125
+ * SELECT * FROM table WHERE JSON_CONTAINS(`related_user1`, JSON_ARRAY('aaaaa'), '$');
126
+ */
127
+ $JSON_ARRAY_CONTAINS: '$jsonArrayContains', // 全文索引 { related_user1:{"$jsonArrayContains":"aaaaa"} }
128
+
129
+ COMPARE_KEYS: new Set<string>([]),
130
+ ALL_KEYS: new Set<string>([]),
131
+ };
132
+
133
+ function initKeysOfConditions() {
134
+ const addIgnoreCase = (keys: Set<string>, key: string) => {
135
+ keys.add(key);
136
+ keys.add(key.toUpperCase());
137
+ keys.add(key.toLowerCase());
138
+ };
139
+
140
+ // 比较操作符, 支持忽略大小写
141
+ KeysOfConditions.COMPARE_KEYS = new Set([]);
142
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NE);
143
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LT);
144
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LTE);
145
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$GT);
146
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$GTE);
147
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$IN);
148
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NIN);
149
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LIKE);
150
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$LIKE_INCLUDE);
151
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NOT_LIKE);
152
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NOT_LIKE_INCLUDE);
153
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$JSON_ARRAY_CONTAINS);
154
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$MATCH);
155
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$MATCH_BOOL);
156
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$RANGE);
157
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NULL);
158
+ addIgnoreCase(KeysOfConditions.COMPARE_KEYS, KeysOfConditions.$NOT_NULL);
159
+
160
+ // 所有操作符
161
+ KeysOfConditions.ALL_KEYS = new Set([...KeysOfConditions.COMPARE_KEYS]);
162
+ addIgnoreCase(KeysOfConditions.ALL_KEYS, KeysOfConditions.$OR);
163
+ }
164
+
165
+ initKeysOfConditions();
@@ -1,75 +1,83 @@
1
- import { camelizeKeys } from 'humps';
2
- import { CrudProServiceBase } from './CrudProServiceBase';
3
- import { IRequestCfgModel } from '../interfaces';
4
- import { MixinUtils } from '../utils/MixinUtils';
5
- import { ICurdProServiceHub } from '../models/ServiceHub';
6
- import MemoryRefreshCache from '../utils/MemoryRefreshCache';
7
-
8
- const methodCache = new MemoryRefreshCache();
9
-
10
-
11
- function parseMethodInfo(methodInfo: any): any {
12
- const row: any = camelizeKeys(methodInfo as object); //转换成驼峰
13
- const configObject = MixinUtils.parseJsonObject(row.moreConfig) || {};
14
- const sqlCfgList = MixinUtils.parseJsonObject(row.sqlCfgList) || [];
15
- return {...configObject, ...row, sqlCfgList};
16
- }
17
-
18
-
19
-
20
- class CrudProCachedCfgService extends CrudProServiceBase {
21
- constructor(serviceHub: ICurdProServiceHub) {
22
- super(serviceHub);
23
- }
24
-
25
- public async getCachedCfgByMethod(method: string, isEnableCache: boolean): Promise<IRequestCfgModel | null> {
26
-
27
- // 不使用缓存
28
- if (!isEnableCache) {
29
- return await this.loadMethodInfo(method)
30
- }
31
-
32
- methodCache.setProps({
33
- keepTime: 2000,
34
- requestFn: () => this.loadMethodInfoList(),
35
- getKeyFn: item => item.method,
36
- });
37
- return await methodCache.getItem(method);
38
- }
39
-
40
-
41
- private async loadMethodInfo(method: string): Promise<any> {
42
- const {methodsTableName, sysDatabaseName} = this.getContextCfg();
43
- const sql = `select *
44
- from ${methodsTableName}
45
- where method = ? `; // 全部加载到内存
46
- const baseInfo = {
47
- tableName: methodsTableName, // // 方法配置的表名,默认 sys_crud_pro_methods
48
- dbName: sysDatabaseName,
49
- };
50
- const [rows] = await this.executeUnsafeQuery(baseInfo, sql, [method]);
51
- const rows2: any[] = rows as object[];
52
- if (rows2.length > 0) {
53
- return parseMethodInfo(rows2[0]);
54
- }
55
- return null;
56
- }
57
-
58
-
59
-
60
- private async loadMethodInfoList(): Promise<any[]> {
61
- const { methodsTableName, sysDatabaseName } = this.getContextCfg();
62
- const sql = `select * from ${methodsTableName}`; // 全部加载到内存
63
- const baseInfo = {
64
- tableName: methodsTableName, // // 方法配置的表名,默认 sys_crud_pro_methods
65
- dbName: sysDatabaseName,
66
- };
67
- const [rows] = await this.executeUnsafeQuery(baseInfo, sql);
68
- const rows2: any[] = rows as object[];
69
- return rows2.map(row => {
70
- return parseMethodInfo(row);
71
- });
72
- }
73
- }
74
-
75
- export { CrudProCachedCfgService };
1
+ import { camelizeKeys } from 'humps';
2
+ import { CrudProServiceBase } from './CrudProServiceBase';
3
+ import { IRequestCfgModel } from '../interfaces';
4
+ import { MixinUtils } from '../utils/MixinUtils';
5
+ import { ICurdProServiceHub } from '../models/ServiceHub';
6
+ import { pickAndConvertRowsByMix } from '../utils/sqlConvert/convertMix';
7
+ import MemoryRefreshCache from '../utils/MemoryRefreshCache';
8
+
9
+ const methodCache = new MemoryRefreshCache();
10
+
11
+ function parseMethodInfo(methodInfo: any): any {
12
+ const row: any = camelizeKeys(methodInfo as object); //转换成驼峰
13
+ const configObject = MixinUtils.parseJsonObject(row.moreConfig) || {};
14
+ const sqlCfgList = MixinUtils.parseJsonObject(row.sqlCfgList) || [];
15
+ return { ...configObject, ...row, sqlCfgList };
16
+ }
17
+
18
+ class CrudProCachedCfgService extends CrudProServiceBase {
19
+ constructor(serviceHub: ICurdProServiceHub) {
20
+ super(serviceHub);
21
+ }
22
+
23
+ public async getCachedCfgByMethod(method: string, isEnableCache: boolean): Promise<IRequestCfgModel | null> {
24
+ const methodInfo = await this.getCachedCfgByMethodInner(method, isEnableCache);
25
+ if (!methodInfo) {
26
+ return null;
27
+ }
28
+ return { ...methodInfo };
29
+ }
30
+
31
+ private async getCachedCfgByMethodInner(method: string, isEnableCache: boolean): Promise<IRequestCfgModel | null> {
32
+ // 不使用缓存
33
+ if (!isEnableCache) {
34
+ return await this.loadMethodInfo(method);
35
+ }
36
+
37
+ methodCache.setProps({
38
+ keepTime: 1000 * 60 * 2, // 2分钟
39
+ requestFn: () => this.loadMethodInfoList(),
40
+ getKeyFn: item => item.method,
41
+ });
42
+ const methodInfo = await methodCache.getItem(method);
43
+ if (methodInfo) {
44
+ return methodInfo;
45
+ }
46
+ return await this.loadMethodInfo(method);
47
+ }
48
+
49
+ private async loadMethodInfo(method: string): Promise<any> {
50
+ const { methodsTableName, sysDatabaseName, sysDatabaseDbType } = this.getContextCfg();
51
+ const sql = `select * from ${methodsTableName} where method = ? `; // 全部加载到内存
52
+
53
+ const baseInfo = {
54
+ sqlTable: methodsTableName,
55
+ sqlDatabase: sysDatabaseName,
56
+ sqlDbType: sysDatabaseDbType,
57
+ };
58
+
59
+ const queryRes = await this.executeUnsafeQuery(baseInfo, sql, [method]);
60
+ const rows2: any[] = pickAndConvertRowsByMix(queryRes, sysDatabaseDbType);
61
+ if (rows2.length > 0) {
62
+ return parseMethodInfo(rows2[0]);
63
+ }
64
+ return null;
65
+ }
66
+
67
+ private async loadMethodInfoList(): Promise<any[]> {
68
+ const { methodsTableName, sysDatabaseName, sysDatabaseDbType } = this.getContextCfg();
69
+ const sql = `select * from ${methodsTableName}`; // 全部加载到内存
70
+ const baseInfo = {
71
+ sqlTable: methodsTableName,
72
+ sqlDatabase: sysDatabaseName,
73
+ sqlDbType: sysDatabaseDbType,
74
+ };
75
+ const queryRes = await this.executeUnsafeQuery(baseInfo, sql);
76
+ const rows2: any[] = pickAndConvertRowsByMix(queryRes, sysDatabaseDbType);
77
+ return rows2.map(row => {
78
+ return parseMethodInfo(row);
79
+ });
80
+ }
81
+ }
82
+
83
+ export { CrudProCachedCfgService };