midway-fatcms 0.0.1-beta.6 → 0.0.1-beta.60

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 (500) 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 +160 -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 +37 -31
  12. package/dist/controller/base/BaseApiController.js +164 -138
  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 +38 -38
  20. package/dist/controller/gateway/CrudStdGatewayController.js +129 -137
  21. package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
  22. package/dist/controller/gateway/DocGatewayController.js +179 -174
  23. package/dist/controller/gateway/FileController.d.ts +26 -25
  24. package/dist/controller/gateway/FileController.js +129 -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 +27 -27
  28. package/dist/controller/gateway/PublicApiController.js +162 -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 +10 -10
  40. package/dist/controller/manage/AppMangeApi.js +88 -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 -176
  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 -149
  67. package/dist/controller/manage/SysConfigMangeApi.d.ts +11 -11
  68. package/dist/controller/manage/SysConfigMangeApi.js +126 -124
  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 +14 -14
  72. package/dist/controller/manage/UserAccountManageApi.js +129 -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 +11 -11
  80. package/dist/controller/render/AppRenderController.js +92 -85
  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 +103 -93
  88. package/dist/index.js +121 -111
  89. package/dist/interface.d.ts +27 -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 +104 -104
  96. package/dist/libs/crud-pro/exceptions.js +117 -117
  97. package/dist/libs/crud-pro/interfaces.d.ts +163 -157
  98. package/dist/libs/crud-pro/interfaces.js +12 -12
  99. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -42
  100. package/dist/libs/crud-pro/models/ExecuteContext.js +79 -79
  101. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -31
  102. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -64
  103. package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
  104. package/dist/libs/crud-pro/models/FuncContext.js +6 -6
  105. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
  106. package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
  107. package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
  108. package/dist/libs/crud-pro/models/RequestModel.js +113 -113
  109. package/dist/libs/crud-pro/models/ResModel.d.ts +16 -0
  110. package/dist/libs/crud-pro/models/ResModel.js +2 -0
  111. package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
  112. package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
  113. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +22 -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 +106 -106
  126. package/dist/libs/crud-pro/models/keys.js +149 -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 +112 -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 +340 -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 +334 -333
  143. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -28
  144. package/dist/libs/crud-pro/services/CrudProServiceBase.js +90 -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 +49 -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 +21 -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 +11 -11
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +11 -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 -0
  189. package/dist/libs/global-config/global-config.js +36 -0
  190. package/dist/libs/utils/base64.d.ts +9 -0
  191. package/dist/libs/utils/base64.js +42 -0
  192. package/dist/libs/utils/common-dto.d.ts +18 -18
  193. package/dist/libs/utils/common-dto.js +40 -40
  194. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  195. package/dist/libs/utils/crypto-utils.js +46 -46
  196. package/dist/libs/utils/errorToString.d.ts +2 -0
  197. package/dist/libs/utils/errorToString.js +57 -0
  198. package/dist/libs/utils/fatcms-request.d.ts +30 -30
  199. package/dist/libs/utils/fatcms-request.js +104 -104
  200. package/dist/libs/utils/functions.d.ts +5 -4
  201. package/dist/libs/utils/functions.js +72 -63
  202. package/dist/libs/utils/ordernum-utils.d.ts +2 -2
  203. package/dist/libs/utils/ordernum-utils.js +13 -13
  204. package/dist/libs/utils/parseConfig.d.ts +7 -7
  205. package/dist/libs/utils/parseConfig.js +44 -44
  206. package/dist/libs/utils/parseCreateSql.d.ts +10 -5
  207. package/dist/libs/utils/parseCreateSql.js +87 -86
  208. package/dist/libs/utils/render-utils.d.ts +28 -28
  209. package/dist/libs/utils/render-utils.js +133 -135
  210. package/dist/middleware/forbidden.middleware.d.ts +10 -10
  211. package/dist/middleware/forbidden.middleware.js +54 -70
  212. package/dist/middleware/global.middleware.d.ts +10 -10
  213. package/dist/middleware/global.middleware.js +266 -246
  214. package/dist/middleware/permission.middleware.d.ts +18 -18
  215. package/dist/middleware/permission.middleware.js +74 -74
  216. package/dist/middleware/rediscache.middleware.d.ts +3 -0
  217. package/dist/middleware/rediscache.middleware.js +77 -0
  218. package/dist/middleware/redislock.middleware.d.ts +7 -0
  219. package/dist/middleware/redislock.middleware.js +72 -0
  220. package/dist/middleware/tx.middleware.d.ts +9 -9
  221. package/dist/middleware/tx.middleware.js +40 -40
  222. package/dist/models/AsyncTaskModel.d.ts +74 -0
  223. package/dist/models/AsyncTaskModel.js +31 -0
  224. package/dist/models/RedisKeys.d.ts +15 -0
  225. package/dist/models/RedisKeys.js +18 -0
  226. package/dist/models/SystemEntities.d.ts +105 -98
  227. package/dist/models/SystemEntities.js +9 -2
  228. package/dist/models/SystemPerm.d.ts +95 -95
  229. package/dist/models/SystemPerm.js +100 -100
  230. package/dist/models/SystemTables.d.ts +25 -27
  231. package/dist/models/SystemTables.js +28 -30
  232. package/dist/models/bizmodels.d.ts +99 -69
  233. package/dist/models/bizmodels.js +39 -34
  234. package/dist/models/contextLogger.d.ts +25 -25
  235. package/dist/models/contextLogger.js +112 -112
  236. package/dist/models/devops.d.ts +12 -12
  237. package/dist/models/devops.js +19 -19
  238. package/dist/models/userSession.d.ts +62 -61
  239. package/dist/models/userSession.js +165 -165
  240. package/dist/schedule/anonymousContext.d.ts +14 -0
  241. package/dist/schedule/anonymousContext.js +59 -0
  242. package/dist/schedule/index.d.ts +4 -3
  243. package/dist/schedule/index.js +10 -69
  244. package/dist/schedule/runSchedule.d.ts +12 -0
  245. package/dist/schedule/runSchedule.js +68 -0
  246. package/dist/schedule/scheduleNames.d.ts +13 -0
  247. package/dist/schedule/scheduleNames.js +17 -0
  248. package/dist/service/AuthService.d.ts +71 -70
  249. package/dist/service/AuthService.js +259 -248
  250. package/dist/service/EnumInfoService.d.ts +30 -30
  251. package/dist/service/EnumInfoService.js +127 -123
  252. package/dist/service/FileCenterService.d.ts +43 -43
  253. package/dist/service/FileCenterService.js +351 -347
  254. package/dist/service/SysConfigService.d.ts +7 -7
  255. package/dist/service/SysConfigService.js +47 -45
  256. package/dist/service/UserAccountService.d.ts +23 -23
  257. package/dist/service/UserAccountService.js +107 -103
  258. package/dist/service/UserSessionService.d.ts +38 -16
  259. package/dist/service/UserSessionService.js +157 -85
  260. package/dist/service/VisitStatService.d.ts +14 -14
  261. package/dist/service/VisitStatService.js +158 -165
  262. package/dist/service/WorkbenchService.d.ts +53 -20
  263. package/dist/service/WorkbenchService.js +211 -153
  264. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  265. package/dist/service/anyapi/AnyApiSandboxService.js +122 -122
  266. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  267. package/dist/service/anyapi/AnyApiService.js +181 -179
  268. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -0
  269. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -0
  270. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -0
  271. package/dist/service/asyncTask/AsyncTaskService.js +34 -0
  272. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
  273. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
  274. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
  275. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -0
  276. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
  277. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -0
  278. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
  279. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -0
  280. package/dist/service/base/ApiBaseService.d.ts +15 -15
  281. package/dist/service/base/ApiBaseService.js +50 -50
  282. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  283. package/dist/service/base/ApiRateLimiter.js +51 -51
  284. package/dist/service/base/BaseService.d.ts +41 -29
  285. package/dist/service/base/BaseService.js +101 -79
  286. package/dist/service/base/RedisCacheService.d.ts +20 -13
  287. package/dist/service/base/RedisCacheService.js +57 -50
  288. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  289. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  290. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  291. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  292. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  293. package/dist/service/crudstd/CrudStdRelationService.js +112 -85
  294. package/dist/service/crudstd/CrudStdService.d.ts +69 -50
  295. package/dist/service/crudstd/CrudStdService.js +392 -182
  296. package/dist/service/curd/CrudProQuick.d.ts +44 -0
  297. package/dist/service/curd/CrudProQuick.js +147 -0
  298. package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
  299. package/dist/service/curd/CurdMixByAccountService.js +92 -87
  300. package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
  301. package/dist/service/curd/CurdMixByDictService.js +114 -111
  302. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -22
  303. package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -154
  304. package/dist/service/curd/CurdMixBySysConfigService.d.ts +9 -9
  305. package/dist/service/curd/CurdMixBySysConfigService.js +80 -78
  306. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +10 -10
  307. package/dist/service/curd/CurdMixByWorkbenchService.js +78 -76
  308. package/dist/service/curd/CurdMixService.d.ts +28 -17
  309. package/dist/service/curd/CurdMixService.js +100 -76
  310. package/dist/service/curd/CurdMixUtils.d.ts +51 -28
  311. package/dist/service/curd/CurdMixUtils.js +277 -201
  312. package/dist/service/curd/CurdProService.d.ts +32 -39
  313. package/dist/service/curd/CurdProService.js +212 -322
  314. package/dist/service/curd/fixCfgModel.d.ts +3 -0
  315. package/dist/service/curd/fixCfgModel.js +104 -0
  316. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  317. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -164
  318. package/dist/service/proxyapi/ProxyApiService.d.ts +61 -60
  319. package/dist/service/proxyapi/ProxyApiService.js +294 -260
  320. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  321. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  322. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  323. package/dist/service/proxyapi/RouteHandler.js +9 -9
  324. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  325. package/dist/service/proxyapi/RouteTrie.js +63 -63
  326. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  327. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  328. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  329. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  330. package/dist/views/404_app.html +31 -31
  331. package/dist/views/404_workbench.html +34 -34
  332. package/index.d.ts +10 -10
  333. package/package.json +87 -75
  334. package/src/config/config.default.ts +179 -203
  335. package/src/config/seed/aeskey.txt +1 -1
  336. package/src/config/utils.ts +22 -23
  337. package/src/configuration.ts +109 -83
  338. package/src/controller/base/BaseApiController.ts +170 -145
  339. package/src/controller/gateway/AnyApiGatewayController.ts +33 -33
  340. package/src/controller/gateway/AsyncTaskController.ts +157 -0
  341. package/src/controller/gateway/CrudMtdGatewayController.ts +116 -107
  342. package/src/controller/gateway/CrudStdGatewayController.ts +87 -101
  343. package/src/controller/gateway/DocGatewayController.ts +173 -165
  344. package/src/controller/gateway/FileController.ts +109 -110
  345. package/src/controller/gateway/ProxyApiGatewayController.ts +47 -47
  346. package/src/controller/gateway/PublicApiController.ts +140 -145
  347. package/src/controller/gateway/StaticController.ts +296 -328
  348. package/src/controller/helpers.controller.ts +161 -161
  349. package/src/controller/home.controller.ts +66 -71
  350. package/src/controller/manage/AnyApiMangeApi.ts +66 -66
  351. package/src/controller/manage/AppLogMangeApi.ts +53 -53
  352. package/src/controller/manage/AppMangeApi.ts +53 -53
  353. package/src/controller/manage/AppPageMangeApi.ts +52 -52
  354. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -49
  355. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -49
  356. package/src/controller/manage/CrudStandardDesignApi.ts +406 -398
  357. package/src/controller/manage/DataDictManageApi.ts +78 -78
  358. package/src/controller/manage/DeployManageApi.ts +175 -179
  359. package/src/controller/manage/DocLibManageApi.ts +69 -69
  360. package/src/controller/manage/DocManageApi.ts +99 -99
  361. package/src/controller/manage/FileManageApi.ts +45 -45
  362. package/src/controller/manage/LowCodeTplManageApi.ts +52 -52
  363. package/src/controller/manage/MenuManageApi.ts +58 -63
  364. package/src/controller/manage/ProxyApiMangeApi.ts +52 -52
  365. package/src/controller/manage/SuperAdminManageApi.ts +139 -138
  366. package/src/controller/manage/SysConfigMangeApi.ts +95 -95
  367. package/src/controller/manage/SystemInfoManageApi.ts +53 -48
  368. package/src/controller/manage/UserAccountManageApi.ts +94 -88
  369. package/src/controller/manage/WorkbenchMangeApi.ts +72 -72
  370. package/src/controller/myinfo/AuthController.ts +108 -174
  371. package/src/controller/myinfo/MyInfoController.ts +32 -32
  372. package/src/controller/render/AppRenderController.ts +81 -76
  373. package/src/controller/test.controller.ts +37 -37
  374. package/src/filter/default.filter.ts +13 -13
  375. package/src/filter/notfound.filter.ts +10 -10
  376. package/src/index.ts +107 -99
  377. package/src/interface.ts +31 -31
  378. package/src/libs/crud-pro/CrudPro.ts +165 -158
  379. package/src/libs/crud-pro/defaultConfigs.ts +15 -13
  380. package/src/libs/crud-pro/exceptions.ts +124 -124
  381. package/src/libs/crud-pro/interfaces.ts +190 -183
  382. package/src/libs/crud-pro/models/ExecuteContext.ts +120 -111
  383. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +96 -86
  384. package/src/libs/crud-pro/models/FuncContext.ts +21 -21
  385. package/src/libs/crud-pro/models/RequestCfgModel.ts +141 -141
  386. package/src/libs/crud-pro/models/RequestModel.ts +141 -141
  387. package/src/libs/crud-pro/models/ResModel.ts +19 -0
  388. package/src/libs/crud-pro/models/ServiceHub.ts +32 -32
  389. package/src/libs/crud-pro/models/SqlCfgModel.ts +52 -52
  390. package/src/libs/crud-pro/models/SqlSegArg.ts +13 -13
  391. package/src/libs/crud-pro/models/Transaction.ts +81 -74
  392. package/src/libs/crud-pro/models/TransactionMySQL.ts +79 -79
  393. package/src/libs/crud-pro/models/TransactionPostgres.ts +91 -91
  394. package/src/libs/crud-pro/models/TransactionSqlServer.ts +102 -107
  395. package/src/libs/crud-pro/models/keys.ts +159 -159
  396. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +83 -75
  397. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +128 -128
  398. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +262 -279
  399. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +60 -60
  400. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +180 -180
  401. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +354 -373
  402. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +185 -202
  403. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +393 -397
  404. package/src/libs/crud-pro/services/CrudProServiceBase.ts +106 -98
  405. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -59
  406. package/src/libs/crud-pro/services/CurdProServiceHub.ts +92 -92
  407. package/src/libs/crud-pro/sql.txt +120 -120
  408. package/src/libs/crud-pro/utils/CompareUtils.ts +23 -23
  409. package/src/libs/crud-pro/utils/DatabaseName.ts +60 -40
  410. package/src/libs/crud-pro/utils/DateTimeUtils.ts +20 -20
  411. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +64 -64
  412. package/src/libs/crud-pro/utils/MessageParseUtils.ts +33 -33
  413. package/src/libs/crud-pro/utils/MixinUtils.ts +285 -285
  414. package/src/libs/crud-pro/utils/ModelUtils.ts +55 -55
  415. package/src/libs/crud-pro/utils/MultiKeyMap.ts +72 -72
  416. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +29 -29
  417. package/src/libs/crud-pro/utils/TypeUtils.ts +188 -188
  418. package/src/libs/crud-pro/utils/ValidateUtils.ts +165 -167
  419. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +20 -20
  420. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +22 -22
  421. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +22 -22
  422. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +21 -26
  423. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +24 -0
  424. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +9 -11
  425. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +9 -11
  426. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +127 -129
  427. package/src/libs/global-config/global-config.ts +108 -0
  428. package/src/libs/utils/base64.ts +40 -0
  429. package/src/libs/utils/common-dto.ts +52 -52
  430. package/src/libs/utils/crypto-utils.ts +50 -52
  431. package/src/libs/utils/errorToString.ts +61 -0
  432. package/src/libs/utils/fatcms-request.ts +103 -115
  433. package/src/libs/utils/functions.ts +78 -67
  434. package/src/libs/utils/ordernum-utils.ts +14 -18
  435. package/src/libs/utils/parseConfig.ts +54 -62
  436. package/src/libs/utils/parseCreateSql.ts +91 -91
  437. package/src/libs/utils/render-utils.ts +175 -184
  438. package/src/middleware/forbidden.middleware.ts +52 -71
  439. package/src/middleware/global.middleware.ts +293 -278
  440. package/src/middleware/permission.middleware.ts +80 -81
  441. package/src/middleware/rediscache.middleware.ts +91 -0
  442. package/src/middleware/redislock.middleware.ts +83 -0
  443. package/src/middleware/tx.middleware.ts +30 -30
  444. package/src/models/AsyncTaskModel.ts +85 -0
  445. package/src/models/RedisKeys.ts +16 -0
  446. package/src/models/SystemEntities.ts +123 -115
  447. package/src/models/SystemPerm.ts +104 -105
  448. package/src/models/SystemTables.ts +26 -30
  449. package/src/models/bizmodels.ts +121 -89
  450. package/src/models/contextLogger.ts +132 -132
  451. package/src/models/devops.ts +17 -17
  452. package/src/models/userSession.ts +217 -216
  453. package/src/schedule/anonymousContext.ts +73 -0
  454. package/src/schedule/index.ts +5 -73
  455. package/src/schedule/runSchedule.ts +74 -0
  456. package/src/schedule/scheduleNames.ts +15 -0
  457. package/src/service/AuthService.ts +283 -270
  458. package/src/service/EnumInfoService.ts +130 -129
  459. package/src/service/FileCenterService.ts +395 -394
  460. package/src/service/SysConfigService.ts +37 -34
  461. package/src/service/UserAccountService.ts +107 -100
  462. package/src/service/UserSessionService.ts +157 -81
  463. package/src/service/VisitStatService.ts +166 -179
  464. package/src/service/WorkbenchService.ts +220 -160
  465. package/src/service/anyapi/AnyApiSandboxService.ts +121 -121
  466. package/src/service/anyapi/AnyApiService.ts +186 -184
  467. package/src/service/asyncTask/AsyncTaskRunnerService.ts +319 -0
  468. package/src/service/asyncTask/AsyncTaskService.ts +21 -0
  469. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  470. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
  471. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +159 -0
  472. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +158 -0
  473. package/src/service/base/ApiBaseService.ts +42 -42
  474. package/src/service/base/ApiRateLimiter.ts +59 -59
  475. package/src/service/base/BaseService.ts +95 -74
  476. package/src/service/base/RedisCacheService.ts +42 -38
  477. package/src/service/crudstd/CrudStdActionService.ts +27 -27
  478. package/src/service/crudstd/CrudStdConstant.ts +62 -62
  479. package/src/service/crudstd/CrudStdRelationService.ts +118 -78
  480. package/src/service/crudstd/CrudStdService.ts +477 -188
  481. package/src/service/curd/CrudProQuick.ts +170 -0
  482. package/src/service/curd/CurdMixByAccountService.ts +89 -83
  483. package/src/service/curd/CurdMixByDictService.ts +114 -113
  484. package/src/service/curd/CurdMixByLinkToCustomService.ts +219 -167
  485. package/src/service/curd/CurdMixBySysConfigService.ts +78 -78
  486. package/src/service/curd/CurdMixByWorkbenchService.ts +71 -68
  487. package/src/service/curd/CurdMixService.ts +97 -65
  488. package/src/service/curd/CurdMixUtils.ts +314 -248
  489. package/src/service/curd/CurdProService.ts +231 -379
  490. package/src/service/curd/fixCfgModel.ts +120 -0
  491. package/src/service/proxyapi/ProxyApiLoadService.ts +170 -165
  492. package/src/service/proxyapi/ProxyApiService.ts +298 -262
  493. package/src/service/proxyapi/ProxyApiUtils.ts +32 -32
  494. package/src/service/proxyapi/RouteHandler.ts +8 -8
  495. package/src/service/proxyapi/RouteTrie.ts +74 -74
  496. package/src/service/proxyapi/WeightedRandom.ts +37 -37
  497. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -44
  498. package/src/views/404_app.html +31 -31
  499. package/src/views/404_workbench.html +34 -34
  500. package/tsconfig.json +32 -0
@@ -1,354 +1,395 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- var __metadata = (this && this.__metadata) || function (k, v) {
9
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.CrudStandardDesignApi = void 0;
13
- const core_1 = require("@midwayjs/core");
14
- const BaseApiController_1 = require("../base/BaseApiController");
15
- const parseCreateSql_1 = require("../../libs/utils/parseCreateSql");
16
- const permission_middleware_1 = require("../../middleware/permission.middleware");
17
- const SystemPerm_1 = require("../../models/SystemPerm");
18
- const keys_1 = require("../../libs/crud-pro/models/keys");
19
- const SystemTables_1 = require("../../models/SystemTables");
20
- const exceptions_1 = require("../../libs/crud-pro/exceptions");
21
- const DatabaseName_1 = require("../../libs/crud-pro/utils/DatabaseName");
22
- const common_dto_1 = require("../../libs/utils/common-dto");
23
- let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiController_1.BaseApiController {
24
- async getDataBaseList() {
25
- const mysqlList = Object.keys(this.mysql2Config || {});
26
- const postgresList = Object.keys(this.postgres2Config || {});
27
- const sqlServerList = Object.keys(this.sqlserver2Config || {});
28
- const toSelectList = (dbCfgNameList, dbType) => {
29
- return dbCfgNameList.map(dbName => {
30
- const value = (0, DatabaseName_1.toDatabaseNameStr)(dbType, dbName);
31
- return { value, label: value, dbName, dbType };
32
- });
33
- };
34
- const mysqlObjList = toSelectList(mysqlList, keys_1.SqlDbType.mysql);
35
- const postgresObjList = toSelectList(postgresList, keys_1.SqlDbType.postgres);
36
- const sqlserverObjList = toSelectList(sqlServerList, keys_1.SqlDbType.sqlserver);
37
- const databaseList = [
38
- ...mysqlObjList,
39
- ...postgresObjList,
40
- ...sqlserverObjList,
41
- ].filter((obj) => {
42
- const value = '' + obj.value;
43
- return !value.endsWith('_fatcms_inner_demo_config');
44
- });
45
- return {
46
- success: true,
47
- data: databaseList,
48
- };
49
- }
50
- async getTableList() {
51
- const { databaseName } = this.ctx.request.body;
52
- const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
53
- if (dbType === keys_1.SqlDbType.postgres) {
54
- return this.getTableListOfPostgreSQL(dbName);
55
- }
56
- if (dbType === keys_1.SqlDbType.sqlserver) {
57
- return this.getTableListOfSqlserver(dbName);
58
- }
59
- const res = await this.curdMixService.executeSQL({
60
- executeSql: 'SHOW TABLES',
61
- sqlDatabase: dbName,
62
- sqlDdType: keys_1.SqlDbType.mysql,
63
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
64
- });
65
- const arr = JSON.parse(JSON.stringify(res));
66
- const tableNames = arr.map(a => {
67
- const v = Object.values(a);
68
- const tableName = v[0];
69
- return {
70
- value: tableName,
71
- label: tableName,
72
- dbName,
73
- dbType,
74
- tableName
75
- };
76
- });
77
- return common_dto_1.CommonResult.successRes(tableNames);
78
- }
79
- async getTableFields() {
80
- const { databaseName, tableName } = this.ctx.request.body;
81
- const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
82
- if (dbType === keys_1.SqlDbType.postgres) {
83
- return this.getTableFieldsOfPostgreSQL(dbName, tableName);
84
- }
85
- if (dbType === keys_1.SqlDbType.sqlserver) {
86
- return this.getTableFieldsOfSqlServer(dbName, tableName);
87
- }
88
- const tableDescribe = await this.curdMixService.executeSQL({
89
- executeSql: 'describe ' + tableName,
90
- sqlDatabase: dbName,
91
- sqlDdType: keys_1.SqlDbType.mysql,
92
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
93
- });
94
- const tableCreate = await this.curdMixService.executeSQL({
95
- executeSql: 'show create table ' + tableName,
96
- sqlDatabase: dbName,
97
- sqlDdType: keys_1.SqlDbType.mysql,
98
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
99
- });
100
- const tableCreateStr = tableCreate[0]['Create Table'];
101
- const { fieldsTitleMap, tableTitle } = (0, parseCreateSql_1.parseCreateSqlToTitleMap)(tableCreateStr);
102
- const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
103
- const fields = tableDescribe2.map(fieldObj => {
104
- const { Default, Extra, Field, Key, Null, Type } = fieldObj;
105
- const fieldTitle = fieldsTitleMap[Field];
106
- return {
107
- fieldIndex: Field || '',
108
- fieldTitle: fieldTitle || Field || '',
109
- isNullable: Null,
110
- defaultValue: Default,
111
- extra: Extra,
112
- key: Key,
113
- type: Type,
114
- };
115
- });
116
- return {
117
- success: true,
118
- data: {
119
- fields,
120
- tableName,
121
- tableTitle,
122
- },
123
- };
124
- }
125
- /**
126
- * 获取角色列表
127
- */
128
- async getRoleOptionsList() {
129
- return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_role, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
130
- }
131
- /**
132
- * 获取功能点列表
133
- */
134
- async getFuncOptionsList() {
135
- return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_func, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
136
- }
137
- async getTableListOfSqlserver(dbName) {
138
- const dbConfig = this.sqlserver2Config[dbName];
139
- if (!dbConfig) {
140
- throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
141
- }
142
- const dbType = keys_1.SqlDbType.sqlserver;
143
- const sql = 'SELECT name as tablename FROM sys.tables';
144
- const arr = await this.curdMixService.executeSQL({
145
- executeSql: sql,
146
- sqlDatabase: dbName,
147
- sqlDdType: dbType,
148
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
149
- executeSqlArgs: [],
150
- });
151
- const tableNames = arr.map(v => {
152
- const tableName = v.tablename;
153
- return {
154
- value: tableName,
155
- label: tableName,
156
- dbName,
157
- dbType,
158
- tableName,
159
- };
160
- });
161
- return common_dto_1.CommonResult.successRes(tableNames);
162
- }
163
- async getTableListOfPostgreSQL(dbName) {
164
- const dbConfig = this.postgres2Config[dbName];
165
- if (!dbConfig) {
166
- throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
167
- }
168
- const dbType = keys_1.SqlDbType.postgres;
169
- const schemaname = 'public';
170
- const tableListSql = '' +
171
- 'SELECT tablename\n' +
172
- 'FROM pg_tables\n' +
173
- `WHERE schemaname = '${schemaname}' \n` +
174
- 'ORDER BY tablename;';
175
- const viewListSql = '' +
176
- 'SELECT viewname as tablename\n' +
177
- 'FROM pg_views\n' +
178
- `WHERE schemaname = '${schemaname}' \n` +
179
- 'ORDER BY viewname;';
180
- const toSelectOptions = async (executeSql, tableType) => {
181
- const arr = await this.curdMixService.executeSQL({
182
- executeSql: executeSql,
183
- sqlDatabase: dbName,
184
- sqlDdType: dbType,
185
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
186
- executeSqlArgs: [],
187
- });
188
- return arr.map(v => {
189
- const tableName = v.tablename;
190
- return {
191
- value: tableName,
192
- label: tableName,
193
- dbName,
194
- dbType,
195
- tableName,
196
- tableType,
197
- };
198
- });
199
- };
200
- const tableNames = await toSelectOptions(tableListSql, 'table');
201
- const viewNames = await toSelectOptions(viewListSql, 'view');
202
- const tableNameMerge = [...tableNames, ...viewNames];
203
- return common_dto_1.CommonResult.successRes(tableNameMerge);
204
- }
205
- async getTableFieldsOfSqlServer(dbName, tableName) {
206
- const dbConfig = this.sqlserver2Config[dbName];
207
- if (!dbConfig) {
208
- throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
209
- }
210
- const columnArraySql = '' +
211
- 'SELECT\n' +
212
- ' c.name AS column_name,\n' +
213
- ' t.name AS data_type,\n' +
214
- ' c.max_length AS max_length,\n' +
215
- ' c.precision,\n' +
216
- ' c.scale,\n' +
217
- ' c.is_nullable,\n' +
218
- ' c.is_identity,\n' +
219
- ' dc.definition AS column_default, \n' +
220
- ' ep.value AS column_description \n' +
221
- 'FROM\n' +
222
- ' sys.columns c\n' +
223
- ' JOIN\n' +
224
- ' sys.types t ON c.user_type_id = t.user_type_id\n' +
225
- ' LEFT JOIN\n' +
226
- ' sys.default_constraints dc\n' +
227
- ' ON c.default_object_id = dc.object_id \n' +
228
- ' LEFT JOIN\n' +
229
- ' sys.extended_properties ep\n' +
230
- ' ON c.object_id = ep.major_id\n' +
231
- ' AND c.column_id = ep.minor_id\n' +
232
- 'WHERE\n' +
233
- ` c.object_id = OBJECT_ID('${tableName}') \n` +
234
- ' ORDER BY\n' +
235
- ' c.column_id;';
236
- const dbType = keys_1.SqlDbType.sqlserver;
237
- const columnArray = await this.curdMixService.executeSQL({
238
- executeSql: columnArraySql,
239
- sqlDatabase: dbName,
240
- sqlDdType: dbType,
241
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
242
- executeSqlArgs: [],
243
- });
244
- const fields = columnArray.map(columnObj => {
245
- const { column_name, is_nullable, column_default, data_type, is_identity, column_description, ...others } = columnObj;
246
- return {
247
- fieldIndex: column_name || '',
248
- fieldTitle: column_description || column_name || '',
249
- isNullable: is_nullable,
250
- defaultValue: column_default || '',
251
- extra: others,
252
- // key: column_name, // 索引
253
- type: data_type,
254
- is_identity: is_identity,
255
- };
256
- });
257
- return common_dto_1.CommonResult.successRes({
258
- fields,
259
- tableName,
260
- tableTitle: tableName,
261
- });
262
- }
263
- async getTableFieldsOfPostgreSQL(dbName, tableName) {
264
- const dbConfig = this.postgres2Config[dbName];
265
- if (!dbConfig) {
266
- throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
267
- }
268
- const schemaname = 'public';
269
- const columnArraySql = `
270
-
271
- SELECT
272
- *
273
- FROM information_schema.columns
274
- WHERE table_schema = $1 and table_name = $2
275
- ORDER BY ordinal_position;
276
-
277
- `.trim();
278
- const dbType = keys_1.SqlDbType.postgres;
279
- const columnArray = await this.curdMixService.executeSQL({
280
- executeSql: columnArraySql,
281
- sqlDatabase: dbName,
282
- sqlDdType: dbType,
283
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
284
- executeSqlArgs: [schemaname, tableName],
285
- });
286
- const fields = columnArray.map(columnObj => {
287
- const { column_name, is_nullable, column_default, data_type, is_identity, ...others } = columnObj;
288
- return {
289
- fieldIndex: column_name || '',
290
- fieldTitle: column_name || '',
291
- isNullable: is_nullable,
292
- defaultValue: column_default || '',
293
- extra: others,
294
- // key: column_name, // 索引
295
- type: data_type,
296
- is_identity: is_identity,
297
- };
298
- });
299
- return {
300
- success: true,
301
- data: {
302
- fields,
303
- tableName,
304
- tableTitle: tableName,
305
- },
306
- };
307
- }
308
- };
309
- __decorate([
310
- (0, core_1.Config)('mysql2'),
311
- __metadata("design:type", Object)
312
- ], CrudStandardDesignApi.prototype, "mysql2Config", void 0);
313
- __decorate([
314
- (0, core_1.Config)('postgres2'),
315
- __metadata("design:type", Object)
316
- ], CrudStandardDesignApi.prototype, "postgres2Config", void 0);
317
- __decorate([
318
- (0, core_1.Config)('sqlserver2'),
319
- __metadata("design:type", Object)
320
- ], CrudStandardDesignApi.prototype, "sqlserver2Config", void 0);
321
- __decorate([
322
- (0, core_1.Post)('/getDataBaseList'),
323
- __metadata("design:type", Function),
324
- __metadata("design:paramtypes", []),
325
- __metadata("design:returntype", Promise)
326
- ], CrudStandardDesignApi.prototype, "getDataBaseList", null);
327
- __decorate([
328
- (0, core_1.Post)('/getTableList'),
329
- __metadata("design:type", Function),
330
- __metadata("design:paramtypes", []),
331
- __metadata("design:returntype", Promise)
332
- ], CrudStandardDesignApi.prototype, "getTableList", null);
333
- __decorate([
334
- (0, core_1.Post)('/getTableFields'),
335
- __metadata("design:type", Function),
336
- __metadata("design:paramtypes", []),
337
- __metadata("design:returntype", Promise)
338
- ], CrudStandardDesignApi.prototype, "getTableFields", null);
339
- __decorate([
340
- (0, core_1.Post)('/getRoleOptionsList'),
341
- __metadata("design:type", Function),
342
- __metadata("design:paramtypes", []),
343
- __metadata("design:returntype", Promise)
344
- ], CrudStandardDesignApi.prototype, "getRoleOptionsList", null);
345
- __decorate([
346
- (0, core_1.Post)('/getFuncOptionsList'),
347
- __metadata("design:type", Function),
348
- __metadata("design:paramtypes", []),
349
- __metadata("design:returntype", Promise)
350
- ], CrudStandardDesignApi.prototype, "getFuncOptionsList", null);
351
- CrudStandardDesignApi = __decorate([
352
- (0, core_1.Controller)('/ns/api/manage/CrudStandardDesignApi', { middleware: [(0, permission_middleware_1.checkPermission)(SystemPerm_1.SystemFuncCode.CrudStandardDesignRead)] })
353
- ], CrudStandardDesignApi);
354
- exports.CrudStandardDesignApi = CrudStandardDesignApi;
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.CrudStandardDesignApi = void 0;
13
+ const core_1 = require("@midwayjs/core");
14
+ const BaseApiController_1 = require("../base/BaseApiController");
15
+ const parseCreateSql_1 = require("../../libs/utils/parseCreateSql");
16
+ const permission_middleware_1 = require("../../middleware/permission.middleware");
17
+ const SystemPerm_1 = require("../../models/SystemPerm");
18
+ const keys_1 = require("../../libs/crud-pro/models/keys");
19
+ const SystemTables_1 = require("../../models/SystemTables");
20
+ const exceptions_1 = require("../../libs/crud-pro/exceptions");
21
+ const DatabaseName_1 = require("../../libs/crud-pro/utils/DatabaseName");
22
+ const common_dto_1 = require("../../libs/utils/common-dto");
23
+ function getObjectKeysWithValue(obj) {
24
+ const keys = Object.keys(obj || {});
25
+ return keys.filter((key) => {
26
+ const valueObj = obj[key];
27
+ const valueKeys = Object.keys(valueObj || {});
28
+ return valueKeys.length > 0;
29
+ });
30
+ }
31
+ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiController_1.BaseApiController {
32
+ async getDataBaseList() {
33
+ const mysqlList = getObjectKeysWithValue(this.mysql2Config);
34
+ const postgresList = getObjectKeysWithValue(this.postgres2Config);
35
+ const sqlServerList = getObjectKeysWithValue(this.sqlserver2Config);
36
+ const toSelectList = (dbCfgNameList, dbType) => {
37
+ return dbCfgNameList.map(dbName => {
38
+ const value = (0, DatabaseName_1.toDatabaseNameStr)(dbType, dbName);
39
+ return { value, label: value, dbName, dbType };
40
+ });
41
+ };
42
+ const mysqlObjList = toSelectList(mysqlList, keys_1.SqlDbType.mysql);
43
+ const postgresObjList = toSelectList(postgresList, keys_1.SqlDbType.postgres);
44
+ const sqlserverObjList = toSelectList(sqlServerList, keys_1.SqlDbType.sqlserver);
45
+ const databaseList = [...mysqlObjList, ...postgresObjList, ...sqlserverObjList].filter((obj) => {
46
+ const value = '' + obj.value;
47
+ return !value.endsWith('_fatcms_inner_demo_config');
48
+ });
49
+ return {
50
+ success: true,
51
+ data: databaseList,
52
+ };
53
+ }
54
+ async getTableList() {
55
+ const { databaseName } = this.ctx.request.body;
56
+ const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
57
+ if (dbType === keys_1.SqlDbType.postgres) {
58
+ return this.getTableListOfPostgreSQL(dbName);
59
+ }
60
+ if (dbType === keys_1.SqlDbType.sqlserver) {
61
+ return this.getTableListOfSqlserver(dbName);
62
+ }
63
+ const res = await this.curdMixService.executeSQL({
64
+ executeSql: 'SHOW TABLES',
65
+ sqlDatabase: dbName,
66
+ sqlDbType: keys_1.SqlDbType.mysql,
67
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
68
+ });
69
+ const arr = JSON.parse(JSON.stringify(res));
70
+ const tableNames = arr.map(a => {
71
+ const v = Object.values(a);
72
+ const tableName = v[0];
73
+ return {
74
+ value: tableName,
75
+ label: tableName,
76
+ dbName,
77
+ dbType,
78
+ tableName,
79
+ };
80
+ });
81
+ return common_dto_1.CommonResult.successRes(tableNames);
82
+ }
83
+ async getTableFields() {
84
+ const { databaseName, tableName } = this.ctx.request.body;
85
+ const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(databaseName);
86
+ if (dbType === keys_1.SqlDbType.postgres) {
87
+ return this.getTableFieldsOfPostgreSQL(dbName, tableName);
88
+ }
89
+ if (dbType === keys_1.SqlDbType.sqlserver) {
90
+ return this.getTableFieldsOfSqlServer(dbName, tableName);
91
+ }
92
+ const tableDescribe = await this.curdMixService.executeSQL({
93
+ executeSql: 'describe ' + tableName,
94
+ sqlDatabase: dbName,
95
+ sqlDbType: keys_1.SqlDbType.mysql,
96
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
97
+ });
98
+ const tableCreate = await this.curdMixService.executeSQL({
99
+ executeSql: 'show create table ' + tableName,
100
+ sqlDatabase: dbName,
101
+ sqlDbType: keys_1.SqlDbType.mysql,
102
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
103
+ });
104
+ const tableCreateStr = tableCreate[0]['Create Table'];
105
+ const { fieldsTitleMap, tableTitle } = (0, parseCreateSql_1.parseCreateSqlToTitleMap)(tableCreateStr);
106
+ const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
107
+ const fields = tableDescribe2.map(fieldObj => {
108
+ const { Default, Extra, Field, Key, Null, Type } = fieldObj;
109
+ const fieldTitle = fieldsTitleMap[Field];
110
+ return {
111
+ fieldIndex: Field || '',
112
+ fieldTitle: fieldTitle || Field || '',
113
+ isNullable: Null,
114
+ defaultValue: Default,
115
+ extra: Extra,
116
+ key: Key,
117
+ type: Type,
118
+ };
119
+ });
120
+ return {
121
+ success: true,
122
+ data: {
123
+ fields,
124
+ tableName,
125
+ tableTitle,
126
+ },
127
+ };
128
+ }
129
+ /**
130
+ * 获取角色列表
131
+ */
132
+ async getRoleOptionsList() {
133
+ return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_role, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
134
+ }
135
+ /**
136
+ * 获取功能点列表
137
+ */
138
+ async getFuncOptionsList() {
139
+ return this.executeSysSimpleSQL(SystemTables_1.SystemTables.sys_perm_func, keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
140
+ }
141
+ async getTableListOfSqlserver(dbName) {
142
+ const dbConfig = this.sqlserver2Config[dbName];
143
+ if (!dbConfig) {
144
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
145
+ }
146
+ const dbType = keys_1.SqlDbType.sqlserver;
147
+ const sql = 'SELECT name as tablename FROM sys.tables';
148
+ const arr = await this.curdMixService.executeSQL({
149
+ executeSql: sql,
150
+ sqlDatabase: dbName,
151
+ sqlDbType: dbType,
152
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
153
+ executeSqlArgs: [],
154
+ });
155
+ const tableNames = arr.map(v => {
156
+ const tableName = v.tablename;
157
+ return {
158
+ value: tableName,
159
+ label: tableName,
160
+ dbName,
161
+ dbType,
162
+ tableName,
163
+ };
164
+ });
165
+ return common_dto_1.CommonResult.successRes(tableNames);
166
+ }
167
+ async getTableListOfPostgreSQL(dbName) {
168
+ const dbConfig = this.postgres2Config[dbName];
169
+ if (!dbConfig) {
170
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
171
+ }
172
+ const dbType = keys_1.SqlDbType.postgres;
173
+ const schemaname = 'public';
174
+ const tableListSql = '' + 'SELECT tablename\n' + 'FROM pg_tables\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY tablename;';
175
+ const viewListSql = '' + 'SELECT viewname as tablename\n' + 'FROM pg_views\n' + `WHERE schemaname = '${schemaname}' \n` + 'ORDER BY viewname;';
176
+ const toSelectOptions = async (executeSql, tableType) => {
177
+ const arr = await this.curdMixService.executeSQL({
178
+ executeSql: executeSql,
179
+ sqlDatabase: dbName,
180
+ sqlDbType: dbType,
181
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
182
+ executeSqlArgs: [],
183
+ });
184
+ return arr.map(v => {
185
+ const tableName = v.tablename;
186
+ return {
187
+ value: tableName,
188
+ label: tableName,
189
+ dbName,
190
+ dbType,
191
+ tableName,
192
+ tableType,
193
+ };
194
+ });
195
+ };
196
+ const tableNames = await toSelectOptions(tableListSql, 'table');
197
+ const viewNames = await toSelectOptions(viewListSql, 'view');
198
+ const tableNameMerge = [...tableNames, ...viewNames];
199
+ return common_dto_1.CommonResult.successRes(tableNameMerge);
200
+ }
201
+ async getTableFieldsOfSqlServer(dbName, tableName) {
202
+ const dbConfig = this.sqlserver2Config[dbName];
203
+ if (!dbConfig) {
204
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
205
+ }
206
+ const columnArraySql = '' +
207
+ 'SELECT\n' +
208
+ ' c.name AS column_name,\n' +
209
+ ' t.name AS data_type,\n' +
210
+ ' c.max_length AS max_length,\n' +
211
+ ' c.precision,\n' +
212
+ ' c.scale,\n' +
213
+ ' c.is_nullable,\n' +
214
+ ' c.is_identity,\n' +
215
+ ' dc.definition AS column_default, \n' +
216
+ ' ep.value AS column_description \n' +
217
+ 'FROM\n' +
218
+ ' sys.columns c\n' +
219
+ ' JOIN\n' +
220
+ ' sys.types t ON c.user_type_id = t.user_type_id\n' +
221
+ ' LEFT JOIN\n' +
222
+ ' sys.default_constraints dc\n' +
223
+ ' ON c.default_object_id = dc.object_id \n' +
224
+ ' LEFT JOIN\n' +
225
+ ' sys.extended_properties ep\n' +
226
+ ' ON c.object_id = ep.major_id\n' +
227
+ ' AND c.column_id = ep.minor_id\n' +
228
+ 'WHERE\n' +
229
+ ` c.object_id = OBJECT_ID('${tableName}') \n` +
230
+ ' ORDER BY\n' +
231
+ ' c.column_id;';
232
+ const dbType = keys_1.SqlDbType.sqlserver;
233
+ const columnArray = await this.curdMixService.executeSQL({
234
+ executeSql: columnArraySql,
235
+ sqlDatabase: dbName,
236
+ sqlDbType: dbType,
237
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
238
+ executeSqlArgs: [],
239
+ });
240
+ const fields = columnArray.map(columnObj => {
241
+ const { column_name, is_nullable, column_default, data_type, is_identity, column_description, ...others } = columnObj;
242
+ return {
243
+ fieldIndex: column_name || '',
244
+ fieldTitle: column_description || column_name || '',
245
+ isNullable: is_nullable,
246
+ defaultValue: column_default || '',
247
+ extra: others,
248
+ // key: column_name, // 索引
249
+ type: data_type,
250
+ is_identity: is_identity,
251
+ };
252
+ });
253
+ return common_dto_1.CommonResult.successRes({
254
+ fields,
255
+ tableName,
256
+ tableTitle: tableName,
257
+ });
258
+ }
259
+ async getTableFieldsOfPostgreSQL(dbName, tableName) {
260
+ const dbConfig = this.postgres2Config[dbName];
261
+ if (!dbConfig) {
262
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
263
+ }
264
+ const schemaname = 'public';
265
+ const columnArraySql = `
266
+
267
+ SELECT
268
+ *
269
+ FROM information_schema.columns
270
+ WHERE table_schema = $1 and table_name = $2
271
+ ORDER BY ordinal_position;
272
+
273
+ `.trim();
274
+ const dbType = keys_1.SqlDbType.postgres;
275
+ const columnArray = await this.curdMixService.executeSQL({
276
+ executeSql: columnArraySql,
277
+ sqlDatabase: dbName,
278
+ sqlDbType: dbType,
279
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
280
+ executeSqlArgs: [schemaname, tableName],
281
+ });
282
+ const commentMap = await this.getTableFieldsCommentsMapOfPostgreSQL(dbName, schemaname, tableName);
283
+ const fields = columnArray.map(columnObj => {
284
+ const { column_name, is_nullable, column_default, data_type, is_identity, ...others } = columnObj;
285
+ return {
286
+ fieldIndex: column_name || '',
287
+ fieldTitle: commentMap[column_name] || column_name || '',
288
+ isNullable: is_nullable,
289
+ defaultValue: column_default || '',
290
+ extra: others,
291
+ // key: column_name, // 索引
292
+ type: data_type,
293
+ is_identity: is_identity,
294
+ };
295
+ });
296
+ return {
297
+ success: true,
298
+ data: {
299
+ fields,
300
+ tableName,
301
+ tableTitle: tableName,
302
+ },
303
+ };
304
+ }
305
+ /**
306
+ * 获取PostgreSQL建表语句的注释
307
+ * @param dbName
308
+ * @param schemaname
309
+ * @param tableName
310
+ * @returns
311
+ */
312
+ async getTableFieldsCommentsMapOfPostgreSQL(dbName, schemaname, tableName) {
313
+ const commentArraySql = `
314
+ SELECT
315
+ n.nspname AS schema_name,
316
+ c.relname AS table_name,
317
+ a.attname AS column_name,
318
+ d.description AS column_comment
319
+ FROM
320
+ pg_class c
321
+ JOIN
322
+ pg_namespace n ON c.relnamespace = n.oid
323
+ JOIN
324
+ pg_attribute a ON c.oid = a.attrelid
325
+ LEFT JOIN
326
+ pg_description d ON c.oid = d.objoid AND a.attnum = d.objsubid
327
+ WHERE
328
+ n.nspname = $1
329
+ AND c.relname = $2
330
+ AND a.attnum > 0
331
+ ORDER BY
332
+ a.attnum
333
+ `;
334
+ const dbType = keys_1.SqlDbType.postgres;
335
+ const commentArray = await this.curdMixService.executeSQL({
336
+ executeSql: commentArraySql,
337
+ sqlDatabase: dbName,
338
+ sqlDbType: dbType,
339
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
340
+ executeSqlArgs: [schemaname, tableName],
341
+ });
342
+ const map = {};
343
+ commentArray.forEach(commentObj => {
344
+ const { column_name, column_comment } = commentObj;
345
+ map[column_name] = (0, parseCreateSql_1.parseTableFieldTitleFromComment)(column_comment);
346
+ });
347
+ return map;
348
+ }
349
+ };
350
+ __decorate([
351
+ (0, core_1.Config)('mysql2'),
352
+ __metadata("design:type", Object)
353
+ ], CrudStandardDesignApi.prototype, "mysql2Config", void 0);
354
+ __decorate([
355
+ (0, core_1.Config)('postgres2'),
356
+ __metadata("design:type", Object)
357
+ ], CrudStandardDesignApi.prototype, "postgres2Config", void 0);
358
+ __decorate([
359
+ (0, core_1.Config)('sqlserver2'),
360
+ __metadata("design:type", Object)
361
+ ], CrudStandardDesignApi.prototype, "sqlserver2Config", void 0);
362
+ __decorate([
363
+ (0, core_1.Post)('/getDataBaseList'),
364
+ __metadata("design:type", Function),
365
+ __metadata("design:paramtypes", []),
366
+ __metadata("design:returntype", Promise)
367
+ ], CrudStandardDesignApi.prototype, "getDataBaseList", null);
368
+ __decorate([
369
+ (0, core_1.Post)('/getTableList'),
370
+ __metadata("design:type", Function),
371
+ __metadata("design:paramtypes", []),
372
+ __metadata("design:returntype", Promise)
373
+ ], CrudStandardDesignApi.prototype, "getTableList", null);
374
+ __decorate([
375
+ (0, core_1.Post)('/getTableFields'),
376
+ __metadata("design:type", Function),
377
+ __metadata("design:paramtypes", []),
378
+ __metadata("design:returntype", Promise)
379
+ ], CrudStandardDesignApi.prototype, "getTableFields", null);
380
+ __decorate([
381
+ (0, core_1.Post)('/getRoleOptionsList'),
382
+ __metadata("design:type", Function),
383
+ __metadata("design:paramtypes", []),
384
+ __metadata("design:returntype", Promise)
385
+ ], CrudStandardDesignApi.prototype, "getRoleOptionsList", null);
386
+ __decorate([
387
+ (0, core_1.Post)('/getFuncOptionsList'),
388
+ __metadata("design:type", Function),
389
+ __metadata("design:paramtypes", []),
390
+ __metadata("design:returntype", Promise)
391
+ ], CrudStandardDesignApi.prototype, "getFuncOptionsList", null);
392
+ CrudStandardDesignApi = __decorate([
393
+ (0, core_1.Controller)('/ns/api/manage/CrudStandardDesignApi', { middleware: [(0, permission_middleware_1.checkPermission)(SystemPerm_1.SystemFuncCode.CrudStandardDesignRead)] })
394
+ ], CrudStandardDesignApi);
395
+ exports.CrudStandardDesignApi = CrudStandardDesignApi;