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,398 +1,406 @@
1
- import * as _ from 'lodash';
2
- import { Config, Controller, Post } from '@midwayjs/core';
3
- import { BaseApiController } from '../base/BaseApiController';
4
- import { parseCreateSqlToTitleMap } from '../../libs/utils/parseCreateSql';
5
- import { checkPermission } from '../../middleware/permission.middleware';
6
- import { SystemFuncCode } from '../../models/SystemPerm';
7
- import { KeyOfCrudTypes, KeysOfSimpleSQL, SqlDbType } from '../../libs/crud-pro/models/keys';
8
- import { SystemTables } from '../../models/SystemTables';
9
- import { CommonException } from "../../libs/crud-pro/exceptions";
10
- import { parseDatabaseName, toDatabaseNameStr } from "../../libs/crud-pro/utils/DatabaseName";
11
- import { CommonResult } from "../../libs/utils/common-dto";
12
-
13
-
14
- @Controller('/ns/api/manage/CrudStandardDesignApi', { middleware: [checkPermission(SystemFuncCode.CrudStandardDesignRead)] })
15
- export class CrudStandardDesignApi extends BaseApiController {
16
- @Config('mysql2')
17
- private mysql2Config: any;
18
-
19
- @Config('postgres2')
20
- private postgres2Config: any;
21
-
22
- @Config('sqlserver2')
23
- private sqlserver2Config: any;
24
-
25
- @Post('/getDataBaseList')
26
- async getDataBaseList() {
27
- const mysqlList = Object.keys(this.mysql2Config || {});
28
- const postgresList = Object.keys(this.postgres2Config || {});
29
- const sqlServerList = Object.keys(this.sqlserver2Config || {});
30
-
31
- const toSelectList = (dbCfgNameList: string[], dbType: SqlDbType) => {
32
- return dbCfgNameList.map(dbName => {
33
- const value = toDatabaseNameStr(dbType, dbName);
34
- return { value, label: value, dbName, dbType };
35
- });
36
- };
37
-
38
- const mysqlObjList = toSelectList(mysqlList, SqlDbType.mysql);
39
- const postgresObjList = toSelectList(postgresList, SqlDbType.postgres);
40
- const sqlserverObjList = toSelectList(sqlServerList, SqlDbType.sqlserver);
41
-
42
- const databaseList = [
43
- ...mysqlObjList,
44
- ...postgresObjList,
45
- ...sqlserverObjList,
46
- ].filter((obj: any) => {
47
- const value = '' + obj.value;
48
- return !value.endsWith('_fatcms_inner_demo_config');
49
- });
50
-
51
- return {
52
- success: true,
53
- data: databaseList,
54
- };
55
- }
56
-
57
- @Post('/getTableList')
58
- async getTableList(): Promise<CommonResult> {
59
- const { databaseName } = this.ctx.request.body as any;
60
- const { dbType, dbName } = parseDatabaseName(databaseName);
61
-
62
- if (dbType === SqlDbType.postgres) {
63
- return this.getTableListOfPostgreSQL(dbName)
64
- }
65
-
66
- if (dbType === SqlDbType.sqlserver) {
67
- return this.getTableListOfSqlserver(dbName)
68
- }
69
-
70
- const res = await this.curdMixService.executeSQL({
71
- executeSql: 'SHOW TABLES',
72
- sqlDatabase: dbName,
73
- sqlDdType: SqlDbType.mysql,
74
- crudType: KeyOfCrudTypes.SYS_QUERY,
75
- });
76
-
77
- const arr = JSON.parse(JSON.stringify(res));
78
- const tableNames: string[] = arr.map(a => {
79
- const v = Object.values(a);
80
- const tableName = v[0];
81
- return {
82
- value: tableName,
83
- label: tableName,
84
- dbName,
85
- dbType,
86
- tableName
87
- }
88
- });
89
- return CommonResult.successRes(tableNames);
90
- }
91
-
92
- @Post('/getTableFields')
93
- async getTableFields() {
94
- const { databaseName, tableName } = this.ctx.request.body as any;
95
- const { dbType, dbName } = parseDatabaseName(databaseName);
96
-
97
- if (dbType === SqlDbType.postgres) {
98
- return this.getTableFieldsOfPostgreSQL(dbName, tableName)
99
- }
100
-
101
- if (dbType === SqlDbType.sqlserver) {
102
- return this.getTableFieldsOfSqlServer(dbName, tableName)
103
- }
104
-
105
- const tableDescribe = await this.curdMixService.executeSQL({
106
- executeSql: 'describe ' + tableName,
107
- sqlDatabase: dbName,
108
- sqlDdType: SqlDbType.mysql,
109
- crudType: KeyOfCrudTypes.SYS_QUERY,
110
- });
111
- const tableCreate = await this.curdMixService.executeSQL({
112
- executeSql: 'show create table ' + tableName,
113
- sqlDatabase: dbName,
114
- sqlDdType: SqlDbType.mysql,
115
- crudType: KeyOfCrudTypes.SYS_QUERY,
116
- });
117
-
118
- const tableCreateStr = tableCreate[0]['Create Table'];
119
- const { fieldsTitleMap, tableTitle } = parseCreateSqlToTitleMap(tableCreateStr);
120
-
121
- const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
122
- const fields = tableDescribe2.map(fieldObj => {
123
- const { Default, Extra, Field, Key, Null, Type } = fieldObj;
124
- const fieldTitle = fieldsTitleMap[Field];
125
- return {
126
- fieldIndex: Field || '',
127
- fieldTitle: fieldTitle || Field || '',
128
- isNullable: Null,
129
- defaultValue: Default,
130
- extra: Extra,
131
- key: Key,
132
- type: Type,
133
- };
134
- });
135
-
136
- return {
137
- success: true,
138
- data: {
139
- fields,
140
- tableName,
141
- tableTitle,
142
- },
143
- };
144
- }
145
-
146
- /**
147
- * 获取角色列表
148
- */
149
- @Post('/getRoleOptionsList')
150
- async getRoleOptionsList() {
151
- return this.executeSysSimpleSQL(
152
- SystemTables.sys_perm_role,
153
- KeysOfSimpleSQL.SIMPLE_QUERY_PAGE
154
- );
155
- }
156
-
157
- /**
158
- * 获取功能点列表
159
- */
160
- @Post('/getFuncOptionsList')
161
- async getFuncOptionsList() {
162
- return this.executeSysSimpleSQL(
163
- SystemTables.sys_perm_func,
164
- KeysOfSimpleSQL.SIMPLE_QUERY_PAGE
165
- );
166
- }
167
-
168
- private async getTableListOfSqlserver(dbName: string): Promise<CommonResult> {
169
- const dbConfig = this.sqlserver2Config[dbName];
170
- if (!dbConfig) {
171
- throw new CommonException(
172
- 'DB_NOT_FOUND',
173
- '数据库配置没有找到:' + dbName
174
- );
175
- }
176
-
177
- const dbType = SqlDbType.sqlserver;
178
-
179
- const sql = 'SELECT name as tablename FROM sys.tables';
180
- const arr = await this.curdMixService.executeSQL({
181
- executeSql: sql,
182
- sqlDatabase: dbName,
183
- sqlDdType: dbType,
184
- crudType: KeyOfCrudTypes.SYS_QUERY,
185
- executeSqlArgs: [],
186
- });
187
-
188
-
189
- const tableNames: string[] = arr.map(v => {
190
- const tableName = v.tablename;
191
- return {
192
- value: tableName, //[dbName, dbType, tableName].join(SPLIT_CONST),
193
- label: tableName,
194
- dbName,
195
- dbType,
196
- tableName,
197
- };
198
- });
199
- return CommonResult.successRes(tableNames);
200
- }
201
-
202
- private async getTableListOfPostgreSQL(dbName: string): Promise<CommonResult> {
203
-
204
- const dbConfig = this.postgres2Config[dbName];
205
- if (!dbConfig) {
206
- throw new CommonException(
207
- 'DB_NOT_FOUND',
208
- '数据库配置没有找到:' + dbName
209
- );
210
- }
211
-
212
- const dbType = SqlDbType.postgres;
213
- const schemaname = 'public';
214
-
215
- const tableListSql =
216
- '' +
217
- 'SELECT tablename\n' +
218
- 'FROM pg_tables\n' +
219
- `WHERE schemaname = '${schemaname}' \n` +
220
- 'ORDER BY tablename;';
221
-
222
- const viewListSql =
223
- '' +
224
- 'SELECT viewname as tablename\n' +
225
- 'FROM pg_views\n' +
226
- `WHERE schemaname = '${schemaname}' \n` +
227
- 'ORDER BY viewname;';
228
-
229
- const toSelectOptions = async (executeSql: string, tableType: string) => {
230
- const arr = await this.curdMixService.executeSQL({
231
- executeSql: executeSql,
232
- sqlDatabase: dbName,
233
- sqlDdType: dbType,
234
- crudType: KeyOfCrudTypes.SYS_QUERY,
235
- executeSqlArgs: [],
236
- });
237
- return arr.map(v => {
238
- const tableName = v.tablename;
239
- return {
240
- value: tableName, //[dbName, dbType, tableName].join(SPLIT_CONST),
241
- label: tableName,
242
- dbName,
243
- dbType,
244
- tableName,
245
- tableType,
246
- };
247
- });
248
- };
249
-
250
- const tableNames: any[] = await toSelectOptions(tableListSql, 'table');
251
- const viewNames: any[] = await toSelectOptions(viewListSql, 'view');
252
-
253
- const tableNameMerge = [...tableNames, ...viewNames];
254
-
255
- return CommonResult.successRes(tableNameMerge);
256
- }
257
-
258
-
259
- private async getTableFieldsOfSqlServer(dbName: string, tableName: string): Promise<CommonResult> {
260
- const dbConfig = this.sqlserver2Config[dbName];
261
- if (!dbConfig) {
262
- throw new CommonException(
263
- 'DB_NOT_FOUND',
264
- '数据库配置没有找到:' + dbName
265
- );
266
- }
267
-
268
- const columnArraySql =
269
- '' +
270
- 'SELECT\n' +
271
- ' c.name AS column_name,\n' +
272
- ' t.name AS data_type,\n' +
273
- ' c.max_length AS max_length,\n' +
274
- ' c.precision,\n' +
275
- ' c.scale,\n' +
276
- ' c.is_nullable,\n' +
277
- ' c.is_identity,\n' +
278
- ' dc.definition AS column_default, \n' +
279
- ' ep.value AS column_description \n' +
280
- 'FROM\n' +
281
- ' sys.columns c\n' +
282
- ' JOIN\n' +
283
- ' sys.types t ON c.user_type_id = t.user_type_id\n' +
284
- ' LEFT JOIN\n' +
285
- ' sys.default_constraints dc\n' +
286
- ' ON c.default_object_id = dc.object_id \n' +
287
- ' LEFT JOIN\n' +
288
- ' sys.extended_properties ep\n' +
289
- ' ON c.object_id = ep.major_id\n' +
290
- ' AND c.column_id = ep.minor_id\n' +
291
- 'WHERE\n' +
292
- ` c.object_id = OBJECT_ID('${tableName}') \n` +
293
- ' ORDER BY\n' +
294
- ' c.column_id;';
295
-
296
- const dbType = SqlDbType.sqlserver;
297
-
298
- const columnArray = await this.curdMixService.executeSQL({
299
- executeSql: columnArraySql,
300
- sqlDatabase: dbName,
301
- sqlDdType: dbType,
302
- crudType: KeyOfCrudTypes.SYS_QUERY,
303
- executeSqlArgs: [],
304
- });
305
-
306
- const fields = columnArray.map(columnObj => {
307
- const {
308
- column_name,
309
- is_nullable,
310
- column_default,
311
- data_type,
312
- is_identity,
313
- column_description,
314
- ...others
315
- } = columnObj;
316
-
317
- return {
318
- fieldIndex: column_name || '',
319
- fieldTitle: column_description || column_name || '',
320
- isNullable: is_nullable,
321
- defaultValue: column_default || '',
322
- extra: others,
323
- // key: column_name, // 索引
324
- type: data_type,
325
- is_identity: is_identity,
326
- };
327
- });
328
-
329
- return CommonResult.successRes({
330
- fields,
331
- tableName,
332
- tableTitle: tableName,
333
- });
334
- }
335
-
336
- private async getTableFieldsOfPostgreSQL(dbName: string, tableName: string) {
337
- const dbConfig = this.postgres2Config[dbName];
338
- if (!dbConfig) {
339
- throw new CommonException(
340
- 'DB_NOT_FOUND',
341
- '数据库配置没有找到:' + dbName
342
- );
343
- }
344
-
345
- const schemaname = 'public';
346
-
347
- const columnArraySql = `
348
-
349
- SELECT
350
- *
351
- FROM information_schema.columns
352
- WHERE table_schema = $1 and table_name = $2
353
- ORDER BY ordinal_position;
354
-
355
- `.trim();
356
-
357
- const dbType = SqlDbType.postgres;
358
-
359
- const columnArray = await this.curdMixService.executeSQL({
360
- executeSql: columnArraySql,
361
- sqlDatabase: dbName,
362
- sqlDdType: dbType,
363
- crudType: KeyOfCrudTypes.SYS_QUERY,
364
- executeSqlArgs: [schemaname, tableName],
365
- });
366
-
367
- const fields = columnArray.map(columnObj => {
368
- const {
369
- column_name,
370
- is_nullable,
371
- column_default,
372
- data_type,
373
- is_identity,
374
- ...others
375
- } = columnObj;
376
-
377
- return {
378
- fieldIndex: column_name || '',
379
- fieldTitle: column_name || '',
380
- isNullable: is_nullable,
381
- defaultValue: column_default || '',
382
- extra: others,
383
- // key: column_name, // 索引
384
- type: data_type,
385
- is_identity: is_identity,
386
- };
387
- });
388
-
389
- return {
390
- success: true,
391
- data: {
392
- fields,
393
- tableName,
394
- tableTitle: tableName,
395
- },
396
- };
397
- }
398
- }
1
+ import { Config, Controller, Post } from '@midwayjs/core';
2
+ import { BaseApiController } from '../base/BaseApiController';
3
+ import { parseCreateSqlToTitleMap, parseTableFieldTitleFromComment } from '@/libs/utils/parseCreateSql';
4
+ import { checkPermission } from '@/middleware/permission.middleware';
5
+ import { SystemFuncCode } from '@/models/SystemPerm';
6
+ import { KeyOfCrudTypes, KeysOfSimpleSQL, SqlDbType } from '@/libs/crud-pro/models/keys';
7
+ import { SystemTables } from '@/models/SystemTables';
8
+ import { CommonException } from '@/libs/crud-pro/exceptions';
9
+ import { parseDatabaseName, toDatabaseNameStr } from '@/libs/crud-pro/utils/DatabaseName';
10
+ import { CommonResult } from '@/libs/utils/common-dto';
11
+
12
+ function getObjectKeysWithValue(obj: any): string[] {
13
+ const keys = Object.keys(obj || {});
14
+ return keys.filter((key: string) => {
15
+ const valueObj = obj[key];
16
+ const valueKeys = Object.keys(valueObj || {});
17
+ return valueKeys.length > 0;
18
+ });
19
+ }
20
+
21
+ @Controller('/ns/api/manage/CrudStandardDesignApi', { middleware: [checkPermission(SystemFuncCode.CrudStandardDesignRead)] })
22
+ export class CrudStandardDesignApi extends BaseApiController {
23
+ @Config('mysql2')
24
+ private mysql2Config: any;
25
+
26
+ @Config('postgres2')
27
+ private postgres2Config: any;
28
+
29
+ @Config('sqlserver2')
30
+ private sqlserver2Config: any;
31
+
32
+ @Post('/getDataBaseList')
33
+ async getDataBaseList() {
34
+ const mysqlList = getObjectKeysWithValue(this.mysql2Config);
35
+ const postgresList = getObjectKeysWithValue(this.postgres2Config);
36
+ const sqlServerList = getObjectKeysWithValue(this.sqlserver2Config);
37
+
38
+ const toSelectList = (dbCfgNameList: string[], dbType: SqlDbType) => {
39
+ return dbCfgNameList.map(dbName => {
40
+ const value = toDatabaseNameStr(dbType, dbName);
41
+ return { value, label: value, dbName, dbType };
42
+ });
43
+ };
44
+
45
+ const mysqlObjList = toSelectList(mysqlList, SqlDbType.mysql);
46
+ const postgresObjList = toSelectList(postgresList, SqlDbType.postgres);
47
+ const sqlserverObjList = toSelectList(sqlServerList, SqlDbType.sqlserver);
48
+
49
+ const databaseList = [...mysqlObjList, ...postgresObjList, ...sqlserverObjList].filter((obj: any) => {
50
+ const value = '' + obj.value;
51
+ return !value.endsWith('_fatcms_inner_demo_config');
52
+ });
53
+
54
+ return {
55
+ success: true,
56
+ data: databaseList,
57
+ };
58
+ }
59
+
60
+ @Post('/getTableList')
61
+ async getTableList(): Promise<CommonResult> {
62
+ const { databaseName } = this.ctx.request.body as any;
63
+ const { dbType, dbName } = parseDatabaseName(databaseName);
64
+
65
+ if (dbType === SqlDbType.postgres) {
66
+ return this.getTableListOfPostgreSQL(dbName);
67
+ }
68
+
69
+ if (dbType === SqlDbType.sqlserver) {
70
+ return this.getTableListOfSqlserver(dbName);
71
+ }
72
+
73
+ const res = await this.curdMixService.executeSQL({
74
+ executeSql: 'SHOW TABLES',
75
+ sqlDatabase: dbName,
76
+ sqlDbType: SqlDbType.mysql,
77
+ crudType: KeyOfCrudTypes.SYS_QUERY,
78
+ });
79
+
80
+ const arr = JSON.parse(JSON.stringify(res));
81
+ const tableNames: string[] = arr.map(a => {
82
+ const v = Object.values(a);
83
+ const tableName = v[0];
84
+ return {
85
+ value: tableName,
86
+ label: tableName,
87
+ dbName,
88
+ dbType,
89
+ tableName,
90
+ };
91
+ });
92
+ return CommonResult.successRes(tableNames);
93
+ }
94
+
95
+ @Post('/getTableFields')
96
+ async getTableFields() {
97
+ const { databaseName, tableName } = this.ctx.request.body as any;
98
+ const { dbType, dbName } = parseDatabaseName(databaseName);
99
+
100
+ if (dbType === SqlDbType.postgres) {
101
+ return this.getTableFieldsOfPostgreSQL(dbName, tableName);
102
+ }
103
+
104
+ if (dbType === SqlDbType.sqlserver) {
105
+ return this.getTableFieldsOfSqlServer(dbName, tableName);
106
+ }
107
+
108
+ const tableDescribe = await this.curdMixService.executeSQL({
109
+ executeSql: 'describe ' + tableName,
110
+ sqlDatabase: dbName,
111
+ sqlDbType: SqlDbType.mysql,
112
+ crudType: KeyOfCrudTypes.SYS_QUERY,
113
+ });
114
+ const tableCreate = await this.curdMixService.executeSQL({
115
+ executeSql: 'show create table ' + tableName,
116
+ sqlDatabase: dbName,
117
+ sqlDbType: SqlDbType.mysql,
118
+ crudType: KeyOfCrudTypes.SYS_QUERY,
119
+ });
120
+
121
+ const tableCreateStr = tableCreate[0]['Create Table'];
122
+ const { fieldsTitleMap, tableTitle } = parseCreateSqlToTitleMap(tableCreateStr);
123
+
124
+ const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
125
+ const fields = tableDescribe2.map(fieldObj => {
126
+ const { Default, Extra, Field, Key, Null, Type } = fieldObj;
127
+ const fieldTitle = fieldsTitleMap[Field];
128
+ return {
129
+ fieldIndex: Field || '',
130
+ fieldTitle: fieldTitle || Field || '',
131
+ isNullable: Null,
132
+ defaultValue: Default,
133
+ extra: Extra,
134
+ key: Key,
135
+ type: Type,
136
+ };
137
+ });
138
+
139
+ return {
140
+ success: true,
141
+ data: {
142
+ fields,
143
+ tableName,
144
+ tableTitle,
145
+ },
146
+ };
147
+ }
148
+
149
+ /**
150
+ * 获取角色列表
151
+ */
152
+ @Post('/getRoleOptionsList')
153
+ async getRoleOptionsList() {
154
+ return this.executeSysSimpleSQL(SystemTables.sys_perm_role, KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
155
+ }
156
+
157
+ /**
158
+ * 获取功能点列表
159
+ */
160
+ @Post('/getFuncOptionsList')
161
+ async getFuncOptionsList() {
162
+ return this.executeSysSimpleSQL(SystemTables.sys_perm_func, KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
163
+ }
164
+
165
+ private async getTableListOfSqlserver(dbName: string): Promise<CommonResult> {
166
+ const dbConfig = this.sqlserver2Config[dbName];
167
+ if (!dbConfig) {
168
+ throw new CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
169
+ }
170
+
171
+ const dbType = SqlDbType.sqlserver;
172
+
173
+ const sql = 'SELECT name as tablename FROM sys.tables';
174
+ const arr = await this.curdMixService.executeSQL({
175
+ executeSql: sql,
176
+ sqlDatabase: dbName,
177
+ sqlDbType: dbType,
178
+ crudType: KeyOfCrudTypes.SYS_QUERY,
179
+ executeSqlArgs: [],
180
+ });
181
+
182
+ const tableNames: string[] = arr.map(v => {
183
+ const tableName = v.tablename;
184
+ return {
185
+ value: tableName, //[dbName, dbType, tableName].join(SPLIT_CONST),
186
+ label: tableName,
187
+ dbName,
188
+ dbType,
189
+ tableName,
190
+ };
191
+ });
192
+ return CommonResult.successRes(tableNames);
193
+ }
194
+
195
+ private async getTableListOfPostgreSQL(dbName: string): Promise<CommonResult> {
196
+ const dbConfig = this.postgres2Config[dbName];
197
+ if (!dbConfig) {
198
+ throw new CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
199
+ }
200
+
201
+ const dbType = SqlDbType.postgres;
202
+ const schemaname = 'public';
203
+
204
+ const tableListSql = '' + 'SELECT tablename\n' + 'FROM pg_tables\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY tablename;';
205
+
206
+ const viewListSql = '' + 'SELECT viewname as tablename\n' + 'FROM pg_views\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY viewname;';
207
+
208
+ const toSelectOptions = async (executeSql: string, tableType: string) => {
209
+ const arr = await this.curdMixService.executeSQL({
210
+ executeSql: executeSql,
211
+ sqlDatabase: dbName,
212
+ sqlDbType: dbType,
213
+ crudType: KeyOfCrudTypes.SYS_QUERY,
214
+ executeSqlArgs: [],
215
+ });
216
+ return arr.map(v => {
217
+ const tableName = v.tablename;
218
+ return {
219
+ value: tableName, //[dbName, dbType, tableName].join(SPLIT_CONST),
220
+ label: tableName,
221
+ dbName,
222
+ dbType,
223
+ tableName,
224
+ tableType,
225
+ };
226
+ });
227
+ };
228
+
229
+ const tableNames: any[] = await toSelectOptions(tableListSql, 'table');
230
+ const viewNames: any[] = await toSelectOptions(viewListSql, 'view');
231
+
232
+ const tableNameMerge = [...tableNames, ...viewNames];
233
+
234
+ return CommonResult.successRes(tableNameMerge);
235
+ }
236
+
237
+ private async getTableFieldsOfSqlServer(dbName: string, tableName: string): Promise<CommonResult> {
238
+ const dbConfig = this.sqlserver2Config[dbName];
239
+ if (!dbConfig) {
240
+ throw new CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
241
+ }
242
+
243
+ const columnArraySql =
244
+ '' +
245
+ 'SELECT\n' +
246
+ ' c.name AS column_name,\n' +
247
+ ' t.name AS data_type,\n' +
248
+ ' c.max_length AS max_length,\n' +
249
+ ' c.precision,\n' +
250
+ ' c.scale,\n' +
251
+ ' c.is_nullable,\n' +
252
+ ' c.is_identity,\n' +
253
+ ' dc.definition AS column_default, \n' +
254
+ ' ep.value AS column_description \n' +
255
+ 'FROM\n' +
256
+ ' sys.columns c\n' +
257
+ ' JOIN\n' +
258
+ ' sys.types t ON c.user_type_id = t.user_type_id\n' +
259
+ ' LEFT JOIN\n' +
260
+ ' sys.default_constraints dc\n' +
261
+ ' ON c.default_object_id = dc.object_id \n' +
262
+ ' LEFT JOIN\n' +
263
+ ' sys.extended_properties ep\n' +
264
+ ' ON c.object_id = ep.major_id\n' +
265
+ ' AND c.column_id = ep.minor_id\n' +
266
+ 'WHERE\n' +
267
+ ` c.object_id = OBJECT_ID('${tableName}') \n` +
268
+ ' ORDER BY\n' +
269
+ ' c.column_id;';
270
+
271
+ const dbType = SqlDbType.sqlserver;
272
+
273
+ const columnArray = await this.curdMixService.executeSQL({
274
+ executeSql: columnArraySql,
275
+ sqlDatabase: dbName,
276
+ sqlDbType: dbType,
277
+ crudType: KeyOfCrudTypes.SYS_QUERY,
278
+ executeSqlArgs: [],
279
+ });
280
+
281
+ const fields = columnArray.map(columnObj => {
282
+ const { column_name, is_nullable, column_default, data_type, is_identity, column_description, ...others } = columnObj;
283
+
284
+ return {
285
+ fieldIndex: column_name || '',
286
+ fieldTitle: column_description || column_name || '',
287
+ isNullable: is_nullable,
288
+ defaultValue: column_default || '',
289
+ extra: others,
290
+ // key: column_name, // 索引
291
+ type: data_type,
292
+ is_identity: is_identity,
293
+ };
294
+ });
295
+
296
+ return CommonResult.successRes({
297
+ fields,
298
+ tableName,
299
+ tableTitle: tableName,
300
+ });
301
+ }
302
+
303
+ private async getTableFieldsOfPostgreSQL(dbName: string, tableName: string) {
304
+ const dbConfig = this.postgres2Config[dbName];
305
+ if (!dbConfig) {
306
+ throw new CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
307
+ }
308
+
309
+ const schemaname = 'public';
310
+
311
+ const columnArraySql = `
312
+
313
+ SELECT
314
+ *
315
+ FROM information_schema.columns
316
+ WHERE table_schema = $1 and table_name = $2
317
+ ORDER BY ordinal_position;
318
+
319
+ `.trim();
320
+
321
+ const dbType = SqlDbType.postgres;
322
+
323
+ const columnArray = await this.curdMixService.executeSQL({
324
+ executeSql: columnArraySql,
325
+ sqlDatabase: dbName,
326
+ sqlDbType: dbType,
327
+ crudType: KeyOfCrudTypes.SYS_QUERY,
328
+ executeSqlArgs: [schemaname, tableName],
329
+ });
330
+
331
+ const commentMap = await this.getTableFieldsCommentsMapOfPostgreSQL(dbName, schemaname, tableName);
332
+
333
+ const fields = columnArray.map(columnObj => {
334
+ const { column_name, is_nullable, column_default, data_type, is_identity, ...others } = columnObj;
335
+
336
+ return {
337
+ fieldIndex: column_name || '',
338
+ fieldTitle: commentMap[column_name] || column_name || '',
339
+ isNullable: is_nullable,
340
+ defaultValue: column_default || '',
341
+ extra: others,
342
+ // key: column_name, // 索引
343
+ type: data_type,
344
+ is_identity: is_identity,
345
+ };
346
+ });
347
+
348
+ return {
349
+ success: true,
350
+ data: {
351
+ fields,
352
+ tableName,
353
+ tableTitle: tableName,
354
+ },
355
+ };
356
+ }
357
+
358
+ /**
359
+ * 获取PostgreSQL建表语句的注释
360
+ * @param dbName
361
+ * @param schemaname
362
+ * @param tableName
363
+ * @returns
364
+ */
365
+ private async getTableFieldsCommentsMapOfPostgreSQL(dbName: string, schemaname: string, tableName: string): Promise<any> {
366
+ const commentArraySql = `
367
+ SELECT
368
+ n.nspname AS schema_name,
369
+ c.relname AS table_name,
370
+ a.attname AS column_name,
371
+ d.description AS column_comment
372
+ FROM
373
+ pg_class c
374
+ JOIN
375
+ pg_namespace n ON c.relnamespace = n.oid
376
+ JOIN
377
+ pg_attribute a ON c.oid = a.attrelid
378
+ LEFT JOIN
379
+ pg_description d ON c.oid = d.objoid AND a.attnum = d.objsubid
380
+ WHERE
381
+ n.nspname = $1
382
+ AND c.relname = $2
383
+ AND a.attnum > 0
384
+ ORDER BY
385
+ a.attnum
386
+ `;
387
+
388
+ const dbType = SqlDbType.postgres;
389
+
390
+ const commentArray = await this.curdMixService.executeSQL({
391
+ executeSql: commentArraySql,
392
+ sqlDatabase: dbName,
393
+ sqlDbType: dbType,
394
+ crudType: KeyOfCrudTypes.SYS_QUERY,
395
+ executeSqlArgs: [schemaname, tableName],
396
+ });
397
+
398
+ const map: any = {};
399
+ commentArray.forEach(commentObj => {
400
+ const { column_name, column_comment } = commentObj;
401
+ map[column_name] = parseTableFieldTitleFromComment(column_comment);
402
+ });
403
+
404
+ return map;
405
+ }
406
+ }