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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (497) hide show
  1. package/.eslintrc.json +14 -14
  2. package/.prettierrc.js +4 -4
  3. package/README.md +8 -8
  4. package/dist/config/config.default.d.ts +3 -3
  5. package/dist/config/config.default.js +160 -160
  6. package/dist/config/utils.d.ts +1 -1
  7. package/dist/config/utils.js +23 -23
  8. package/dist/configuration.d.ts +7 -7
  9. package/dist/configuration.js +113 -113
  10. package/dist/controller/base/BaseApiController.d.ts +37 -37
  11. package/dist/controller/base/BaseApiController.js +164 -164
  12. package/dist/controller/gateway/AnyApiGatewayController.d.ts +13 -13
  13. package/dist/controller/gateway/AnyApiGatewayController.js +55 -55
  14. package/dist/controller/gateway/AsyncTaskController.d.ts +20 -20
  15. package/dist/controller/gateway/AsyncTaskController.js +181 -181
  16. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
  17. package/dist/controller/gateway/CrudMtdGatewayController.js +122 -119
  18. package/dist/controller/gateway/CrudStdGatewayController.d.ts +38 -38
  19. package/dist/controller/gateway/CrudStdGatewayController.js +129 -129
  20. package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
  21. package/dist/controller/gateway/DocGatewayController.js +179 -179
  22. package/dist/controller/gateway/FileController.d.ts +26 -26
  23. package/dist/controller/gateway/FileController.js +129 -129
  24. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
  25. package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
  26. package/dist/controller/gateway/PublicApiController.d.ts +27 -27
  27. package/dist/controller/gateway/PublicApiController.js +162 -162
  28. package/dist/controller/gateway/StaticController.d.ts +23 -23
  29. package/dist/controller/gateway/StaticController.js +286 -286
  30. package/dist/controller/helpers.controller.d.ts +39 -39
  31. package/dist/controller/helpers.controller.js +188 -188
  32. package/dist/controller/home.controller.d.ts +9 -9
  33. package/dist/controller/home.controller.js +72 -72
  34. package/dist/controller/manage/AnyApiMangeApi.d.ts +10 -10
  35. package/dist/controller/manage/AnyApiMangeApi.js +98 -98
  36. package/dist/controller/manage/AppLogMangeApi.d.ts +10 -10
  37. package/dist/controller/manage/AppLogMangeApi.js +88 -88
  38. package/dist/controller/manage/AppMangeApi.d.ts +10 -10
  39. package/dist/controller/manage/AppMangeApi.js +88 -88
  40. package/dist/controller/manage/AppPageMangeApi.d.ts +10 -10
  41. package/dist/controller/manage/AppPageMangeApi.js +87 -87
  42. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +10 -10
  43. package/dist/controller/manage/AppSchemaHistoryApi.js +83 -83
  44. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +10 -10
  45. package/dist/controller/manage/CrudMethodsMangeApi.js +84 -84
  46. package/dist/controller/manage/CrudStandardDesignApi.d.ts +46 -46
  47. package/dist/controller/manage/CrudStandardDesignApi.js +395 -395
  48. package/dist/controller/manage/DataDictManageApi.d.ts +15 -15
  49. package/dist/controller/manage/DataDictManageApi.js +133 -133
  50. package/dist/controller/manage/DeployManageApi.d.ts +19 -19
  51. package/dist/controller/manage/DeployManageApi.js +180 -180
  52. package/dist/controller/manage/DocLibManageApi.d.ts +10 -10
  53. package/dist/controller/manage/DocLibManageApi.js +104 -104
  54. package/dist/controller/manage/DocManageApi.d.ts +11 -11
  55. package/dist/controller/manage/DocManageApi.js +130 -130
  56. package/dist/controller/manage/FileManageApi.d.ts +13 -13
  57. package/dist/controller/manage/FileManageApi.js +77 -77
  58. package/dist/controller/manage/LowCodeTplManageApi.d.ts +13 -13
  59. package/dist/controller/manage/LowCodeTplManageApi.js +86 -86
  60. package/dist/controller/manage/MenuManageApi.d.ts +10 -10
  61. package/dist/controller/manage/MenuManageApi.js +93 -93
  62. package/dist/controller/manage/ProxyApiMangeApi.d.ts +10 -10
  63. package/dist/controller/manage/ProxyApiMangeApi.js +87 -87
  64. package/dist/controller/manage/SuperAdminManageApi.d.ts +24 -24
  65. package/dist/controller/manage/SuperAdminManageApi.js +153 -153
  66. package/dist/controller/manage/SysConfigMangeApi.d.ts +11 -11
  67. package/dist/controller/manage/SysConfigMangeApi.js +126 -126
  68. package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
  69. package/dist/controller/manage/SystemInfoManageApi.js +72 -72
  70. package/dist/controller/manage/UserAccountManageApi.d.ts +14 -14
  71. package/dist/controller/manage/UserAccountManageApi.js +129 -129
  72. package/dist/controller/manage/WorkbenchMangeApi.d.ts +11 -11
  73. package/dist/controller/manage/WorkbenchMangeApi.js +103 -103
  74. package/dist/controller/myinfo/AuthController.d.ts +33 -33
  75. package/dist/controller/myinfo/AuthController.js +136 -136
  76. package/dist/controller/myinfo/MyInfoController.d.ts +13 -13
  77. package/dist/controller/myinfo/MyInfoController.js +51 -51
  78. package/dist/controller/render/AppRenderController.d.ts +11 -11
  79. package/dist/controller/render/AppRenderController.js +92 -92
  80. package/dist/controller/test.controller.d.ts +8 -8
  81. package/dist/controller/test.controller.js +51 -51
  82. package/dist/filter/default.filter.d.ts +7 -7
  83. package/dist/filter/default.filter.js +23 -23
  84. package/dist/filter/notfound.filter.d.ts +5 -5
  85. package/dist/filter/notfound.filter.js +20 -20
  86. package/dist/index.d.ts +103 -103
  87. package/dist/index.js +121 -121
  88. package/dist/interface.d.ts +27 -27
  89. package/dist/interface.js +3 -3
  90. package/dist/libs/crud-pro/CrudPro.d.ts +37 -37
  91. package/dist/libs/crud-pro/CrudPro.js +136 -136
  92. package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
  93. package/dist/libs/crud-pro/defaultConfigs.js +15 -15
  94. package/dist/libs/crud-pro/exceptions.d.ts +104 -104
  95. package/dist/libs/crud-pro/exceptions.js +117 -117
  96. package/dist/libs/crud-pro/interfaces.d.ts +163 -163
  97. package/dist/libs/crud-pro/interfaces.js +12 -12
  98. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -49
  99. package/dist/libs/crud-pro/models/ExecuteContext.js +79 -79
  100. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -38
  101. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -72
  102. package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
  103. package/dist/libs/crud-pro/models/FuncContext.js +6 -6
  104. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
  105. package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
  106. package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
  107. package/dist/libs/crud-pro/models/RequestModel.js +113 -113
  108. package/dist/libs/crud-pro/models/ResModel.d.ts +16 -16
  109. package/dist/libs/crud-pro/models/ResModel.js +2 -2
  110. package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
  111. package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
  112. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +22 -22
  113. package/dist/libs/crud-pro/models/SqlCfgModel.js +40 -40
  114. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +6 -6
  115. package/dist/libs/crud-pro/models/SqlSegArg.js +12 -12
  116. package/dist/libs/crud-pro/models/Transaction.d.ts +30 -30
  117. package/dist/libs/crud-pro/models/Transaction.js +74 -74
  118. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +28 -28
  119. package/dist/libs/crud-pro/models/TransactionMySQL.js +76 -76
  120. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +28 -28
  121. package/dist/libs/crud-pro/models/TransactionPostgres.js +85 -85
  122. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +34 -34
  123. package/dist/libs/crud-pro/models/TransactionSqlServer.js +92 -92
  124. package/dist/libs/crud-pro/models/keys.d.ts +106 -106
  125. package/dist/libs/crud-pro/models/keys.js +149 -149
  126. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -11
  127. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -73
  128. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
  129. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +112 -112
  130. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
  131. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -225
  132. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +9 -9
  133. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +51 -51
  134. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +13 -13
  135. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +148 -148
  136. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +24 -24
  137. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +340 -340
  138. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
  139. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -165
  140. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
  141. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +334 -334
  142. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -24
  143. package/dist/libs/crud-pro/services/CrudProServiceBase.js +90 -90
  144. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -9
  145. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +72 -72
  146. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +32 -32
  147. package/dist/libs/crud-pro/services/CurdProServiceHub.js +64 -64
  148. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +9 -9
  149. package/dist/libs/crud-pro/utils/CompareUtils.js +25 -25
  150. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +9 -9
  151. package/dist/libs/crud-pro/utils/DatabaseName.js +50 -50
  152. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +7 -7
  153. package/dist/libs/crud-pro/utils/DateTimeUtils.js +21 -21
  154. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +19 -19
  155. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +47 -47
  156. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +5 -5
  157. package/dist/libs/crud-pro/utils/MessageParseUtils.js +33 -33
  158. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +39 -39
  159. package/dist/libs/crud-pro/utils/MixinUtils.js +255 -255
  160. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +11 -11
  161. package/dist/libs/crud-pro/utils/ModelUtils.js +49 -49
  162. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +11 -11
  163. package/dist/libs/crud-pro/utils/MultiKeyMap.js +63 -63
  164. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +5 -5
  165. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +29 -29
  166. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +40 -40
  167. package/dist/libs/crud-pro/utils/TypeUtils.js +166 -166
  168. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +3 -3
  169. package/dist/libs/crud-pro/utils/ValidateUtils.js +165 -165
  170. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +3 -3
  171. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +19 -19
  172. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +3 -3
  173. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +20 -20
  174. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +3 -3
  175. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +20 -20
  176. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +4 -4
  177. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +21 -21
  178. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -3
  179. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -22
  180. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +2 -2
  181. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +11 -11
  182. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  183. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +11 -11
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +2 -2
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +128 -128
  186. package/dist/libs/global-config/global-config.d.ts +69 -60
  187. package/dist/libs/global-config/global-config.js +36 -35
  188. package/dist/libs/utils/base64.d.ts +9 -9
  189. package/dist/libs/utils/base64.js +42 -42
  190. package/dist/libs/utils/common-dto.d.ts +18 -18
  191. package/dist/libs/utils/common-dto.js +40 -40
  192. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  193. package/dist/libs/utils/crypto-utils.js +46 -46
  194. package/dist/libs/utils/errorToString.d.ts +2 -2
  195. package/dist/libs/utils/errorToString.js +57 -57
  196. package/dist/libs/utils/fatcms-request.d.ts +30 -30
  197. package/dist/libs/utils/fatcms-request.js +104 -104
  198. package/dist/libs/utils/functions.d.ts +5 -5
  199. package/dist/libs/utils/functions.js +72 -72
  200. package/dist/libs/utils/ordernum-utils.d.ts +2 -2
  201. package/dist/libs/utils/ordernum-utils.js +13 -13
  202. package/dist/libs/utils/parseConfig.d.ts +7 -7
  203. package/dist/libs/utils/parseConfig.js +44 -44
  204. package/dist/libs/utils/parseCreateSql.d.ts +10 -10
  205. package/dist/libs/utils/parseCreateSql.js +87 -87
  206. package/dist/libs/utils/render-utils.d.ts +28 -28
  207. package/dist/libs/utils/render-utils.js +133 -135
  208. package/dist/middleware/forbidden.middleware.d.ts +10 -10
  209. package/dist/middleware/forbidden.middleware.js +54 -54
  210. package/dist/middleware/global.middleware.d.ts +10 -10
  211. package/dist/middleware/global.middleware.js +266 -266
  212. package/dist/middleware/permission.middleware.d.ts +18 -18
  213. package/dist/middleware/permission.middleware.js +74 -74
  214. package/dist/middleware/rediscache.middleware.d.ts +3 -3
  215. package/dist/middleware/rediscache.middleware.js +77 -77
  216. package/dist/middleware/redislock.middleware.d.ts +7 -7
  217. package/dist/middleware/redislock.middleware.js +72 -72
  218. package/dist/middleware/tx.middleware.d.ts +9 -9
  219. package/dist/middleware/tx.middleware.js +40 -40
  220. package/dist/models/AsyncTaskModel.d.ts +74 -74
  221. package/dist/models/AsyncTaskModel.js +31 -31
  222. package/dist/models/RedisKeys.d.ts +15 -15
  223. package/dist/models/RedisKeys.js +18 -18
  224. package/dist/models/SystemEntities.d.ts +105 -105
  225. package/dist/models/SystemEntities.js +9 -9
  226. package/dist/models/SystemPerm.d.ts +95 -95
  227. package/dist/models/SystemPerm.js +100 -100
  228. package/dist/models/SystemTables.d.ts +25 -25
  229. package/dist/models/SystemTables.js +28 -28
  230. package/dist/models/bizmodels.d.ts +99 -99
  231. package/dist/models/bizmodels.js +39 -39
  232. package/dist/models/contextLogger.d.ts +25 -25
  233. package/dist/models/contextLogger.js +112 -112
  234. package/dist/models/devops.d.ts +12 -12
  235. package/dist/models/devops.js +19 -19
  236. package/dist/models/userSession.d.ts +62 -62
  237. package/dist/models/userSession.js +165 -165
  238. package/dist/schedule/anonymousContext.d.ts +14 -14
  239. package/dist/schedule/anonymousContext.js +59 -59
  240. package/dist/schedule/index.d.ts +4 -4
  241. package/dist/schedule/index.js +10 -10
  242. package/dist/schedule/runSchedule.d.ts +12 -12
  243. package/dist/schedule/runSchedule.js +68 -68
  244. package/dist/schedule/scheduleNames.d.ts +13 -13
  245. package/dist/schedule/scheduleNames.js +17 -17
  246. package/dist/service/AuthService.d.ts +71 -71
  247. package/dist/service/AuthService.js +259 -259
  248. package/dist/service/EnumInfoService.d.ts +30 -30
  249. package/dist/service/EnumInfoService.js +127 -127
  250. package/dist/service/FileCenterService.d.ts +43 -43
  251. package/dist/service/FileCenterService.js +351 -351
  252. package/dist/service/SysConfigService.d.ts +7 -7
  253. package/dist/service/SysConfigService.js +47 -47
  254. package/dist/service/UserAccountService.d.ts +23 -23
  255. package/dist/service/UserAccountService.js +107 -107
  256. package/dist/service/UserSessionService.d.ts +38 -38
  257. package/dist/service/UserSessionService.js +157 -157
  258. package/dist/service/VisitStatService.d.ts +14 -14
  259. package/dist/service/VisitStatService.js +158 -158
  260. package/dist/service/WorkbenchService.d.ts +53 -53
  261. package/dist/service/WorkbenchService.js +211 -211
  262. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  263. package/dist/service/anyapi/AnyApiSandboxService.js +110 -110
  264. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  265. package/dist/service/anyapi/AnyApiService.js +181 -181
  266. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -50
  267. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -287
  268. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -7
  269. package/dist/service/asyncTask/AsyncTaskService.js +34 -34
  270. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -10
  271. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -2
  272. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -7
  273. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -216
  274. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -36
  275. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -141
  276. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -46
  277. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -135
  278. package/dist/service/base/ApiBaseService.d.ts +15 -15
  279. package/dist/service/base/ApiBaseService.js +50 -50
  280. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  281. package/dist/service/base/ApiRateLimiter.js +51 -51
  282. package/dist/service/base/BaseService.d.ts +41 -41
  283. package/dist/service/base/BaseService.js +101 -101
  284. package/dist/service/base/RedisCacheService.d.ts +20 -20
  285. package/dist/service/base/RedisCacheService.js +57 -57
  286. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  287. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  288. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  289. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  290. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  291. package/dist/service/crudstd/CrudStdRelationService.js +112 -112
  292. package/dist/service/crudstd/CrudStdService.d.ts +69 -68
  293. package/dist/service/crudstd/CrudStdService.js +380 -347
  294. package/dist/service/curd/CrudProQuick.d.ts +44 -44
  295. package/dist/service/curd/CrudProQuick.js +147 -147
  296. package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
  297. package/dist/service/curd/CurdMixByAccountService.js +92 -92
  298. package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
  299. package/dist/service/curd/CurdMixByDictService.js +114 -114
  300. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -31
  301. package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -203
  302. package/dist/service/curd/CurdMixBySysConfigService.d.ts +9 -9
  303. package/dist/service/curd/CurdMixBySysConfigService.js +80 -80
  304. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +10 -10
  305. package/dist/service/curd/CurdMixByWorkbenchService.js +78 -78
  306. package/dist/service/curd/CurdMixService.d.ts +28 -28
  307. package/dist/service/curd/CurdMixService.js +100 -100
  308. package/dist/service/curd/CurdMixUtils.d.ts +51 -51
  309. package/dist/service/curd/CurdMixUtils.js +277 -277
  310. package/dist/service/curd/CurdProService.d.ts +32 -32
  311. package/dist/service/curd/CurdProService.js +212 -212
  312. package/dist/service/curd/fixCfgModel.d.ts +3 -3
  313. package/dist/service/curd/fixCfgModel.js +104 -104
  314. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  315. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  316. package/dist/service/proxyapi/ProxyApiService.d.ts +61 -61
  317. package/dist/service/proxyapi/ProxyApiService.js +294 -294
  318. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  319. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  320. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  321. package/dist/service/proxyapi/RouteHandler.js +9 -9
  322. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  323. package/dist/service/proxyapi/RouteTrie.js +63 -63
  324. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  325. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  326. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  327. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  328. package/index.d.ts +10 -10
  329. package/package.json +87 -81
  330. package/src/config/config.default.ts +179 -0
  331. package/src/config/seed/aeskey.txt +1 -0
  332. package/src/config/utils.ts +22 -0
  333. package/src/configuration.ts +109 -0
  334. package/src/controller/base/BaseApiController.ts +170 -0
  335. package/src/controller/gateway/AnyApiGatewayController.ts +33 -0
  336. package/src/controller/gateway/AsyncTaskController.ts +157 -0
  337. package/src/controller/gateway/CrudMtdGatewayController.ts +116 -0
  338. package/src/controller/gateway/CrudStdGatewayController.ts +87 -0
  339. package/src/controller/gateway/DocGatewayController.ts +173 -0
  340. package/src/controller/gateway/FileController.ts +109 -0
  341. package/src/controller/gateway/ProxyApiGatewayController.ts +47 -0
  342. package/src/controller/gateway/PublicApiController.ts +140 -0
  343. package/src/controller/gateway/StaticController.ts +296 -0
  344. package/src/controller/helpers.controller.ts +161 -0
  345. package/src/controller/home.controller.ts +66 -0
  346. package/src/controller/manage/AnyApiMangeApi.ts +66 -0
  347. package/src/controller/manage/AppLogMangeApi.ts +53 -0
  348. package/src/controller/manage/AppMangeApi.ts +53 -0
  349. package/src/controller/manage/AppPageMangeApi.ts +52 -0
  350. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -0
  351. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -0
  352. package/src/controller/manage/CrudStandardDesignApi.ts +406 -0
  353. package/src/controller/manage/DataDictManageApi.ts +78 -0
  354. package/src/controller/manage/DeployManageApi.ts +175 -0
  355. package/src/controller/manage/DocLibManageApi.ts +69 -0
  356. package/src/controller/manage/DocManageApi.ts +99 -0
  357. package/src/controller/manage/FileManageApi.ts +45 -0
  358. package/src/controller/manage/LowCodeTplManageApi.ts +52 -0
  359. package/src/controller/manage/MenuManageApi.ts +58 -0
  360. package/src/controller/manage/ProxyApiMangeApi.ts +52 -0
  361. package/src/controller/manage/SuperAdminManageApi.ts +139 -0
  362. package/src/controller/manage/SysConfigMangeApi.ts +95 -0
  363. package/src/controller/manage/SystemInfoManageApi.ts +53 -0
  364. package/src/controller/manage/UserAccountManageApi.ts +94 -0
  365. package/src/controller/manage/WorkbenchMangeApi.ts +72 -0
  366. package/src/controller/myinfo/AuthController.ts +108 -0
  367. package/src/controller/myinfo/MyInfoController.ts +32 -0
  368. package/src/controller/render/AppRenderController.ts +81 -0
  369. package/src/controller/test.controller.ts +37 -0
  370. package/src/filter/default.filter.ts +13 -0
  371. package/src/filter/notfound.filter.ts +10 -0
  372. package/src/index.ts +107 -0
  373. package/src/interface.ts +31 -0
  374. package/src/libs/crud-pro/CrudPro.ts +165 -0
  375. package/src/libs/crud-pro/defaultConfigs.ts +15 -0
  376. package/src/libs/crud-pro/exceptions.ts +124 -0
  377. package/src/libs/crud-pro/interfaces.ts +190 -0
  378. package/src/libs/crud-pro/models/ExecuteContext.ts +120 -0
  379. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +96 -0
  380. package/src/libs/crud-pro/models/FuncContext.ts +21 -0
  381. package/src/libs/crud-pro/models/RequestCfgModel.ts +141 -0
  382. package/src/libs/crud-pro/models/RequestModel.ts +141 -0
  383. package/src/libs/crud-pro/models/ResModel.ts +19 -0
  384. package/src/libs/crud-pro/models/ServiceHub.ts +32 -0
  385. package/src/libs/crud-pro/models/SqlCfgModel.ts +52 -0
  386. package/src/libs/crud-pro/models/SqlSegArg.ts +13 -0
  387. package/src/libs/crud-pro/models/Transaction.ts +81 -0
  388. package/src/libs/crud-pro/models/TransactionMySQL.ts +79 -0
  389. package/src/libs/crud-pro/models/TransactionPostgres.ts +91 -0
  390. package/src/libs/crud-pro/models/TransactionSqlServer.ts +102 -0
  391. package/src/libs/crud-pro/models/keys.ts +159 -0
  392. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +83 -0
  393. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +128 -0
  394. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +262 -0
  395. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +60 -0
  396. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +180 -0
  397. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +354 -0
  398. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +185 -0
  399. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +393 -0
  400. package/src/libs/crud-pro/services/CrudProServiceBase.ts +106 -0
  401. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -0
  402. package/src/libs/crud-pro/services/CurdProServiceHub.ts +92 -0
  403. package/src/libs/crud-pro/sql.txt +120 -0
  404. package/src/libs/crud-pro/utils/CompareUtils.ts +23 -0
  405. package/src/libs/crud-pro/utils/DatabaseName.ts +60 -0
  406. package/src/libs/crud-pro/utils/DateTimeUtils.ts +20 -0
  407. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +64 -0
  408. package/src/libs/crud-pro/utils/MessageParseUtils.ts +33 -0
  409. package/src/libs/crud-pro/utils/MixinUtils.ts +285 -0
  410. package/src/libs/crud-pro/utils/ModelUtils.ts +55 -0
  411. package/src/libs/crud-pro/utils/MultiKeyMap.ts +72 -0
  412. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +29 -0
  413. package/src/libs/crud-pro/utils/TypeUtils.ts +188 -0
  414. package/src/libs/crud-pro/utils/ValidateUtils.ts +165 -0
  415. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +20 -0
  416. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +22 -0
  417. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +22 -0
  418. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +21 -0
  419. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +24 -0
  420. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +9 -0
  421. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +9 -0
  422. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +127 -0
  423. package/src/libs/global-config/global-config.ts +108 -0
  424. package/src/libs/utils/base64.ts +40 -0
  425. package/src/libs/utils/common-dto.ts +52 -0
  426. package/src/libs/utils/crypto-utils.ts +50 -0
  427. package/src/libs/utils/errorToString.ts +61 -0
  428. package/src/libs/utils/fatcms-request.ts +103 -0
  429. package/src/libs/utils/functions.ts +78 -0
  430. package/src/libs/utils/ordernum-utils.ts +14 -0
  431. package/src/libs/utils/parseConfig.ts +54 -0
  432. package/src/libs/utils/parseCreateSql.ts +91 -0
  433. package/src/libs/utils/render-utils.ts +175 -0
  434. package/src/middleware/forbidden.middleware.ts +52 -0
  435. package/src/middleware/global.middleware.ts +293 -0
  436. package/src/middleware/permission.middleware.ts +80 -0
  437. package/src/middleware/rediscache.middleware.ts +91 -0
  438. package/src/middleware/redislock.middleware.ts +83 -0
  439. package/src/middleware/tx.middleware.ts +30 -0
  440. package/src/models/AsyncTaskModel.ts +85 -0
  441. package/src/models/RedisKeys.ts +16 -0
  442. package/src/models/SystemEntities.ts +123 -0
  443. package/src/models/SystemPerm.ts +104 -0
  444. package/src/models/SystemTables.ts +26 -0
  445. package/src/models/bizmodels.ts +121 -0
  446. package/src/models/contextLogger.ts +132 -0
  447. package/src/models/devops.ts +17 -0
  448. package/src/models/userSession.ts +217 -0
  449. package/src/schedule/anonymousContext.ts +73 -0
  450. package/src/schedule/index.ts +5 -0
  451. package/src/schedule/runSchedule.ts +74 -0
  452. package/src/schedule/scheduleNames.ts +15 -0
  453. package/src/service/AuthService.ts +283 -0
  454. package/src/service/EnumInfoService.ts +130 -0
  455. package/src/service/FileCenterService.ts +395 -0
  456. package/src/service/SysConfigService.ts +37 -0
  457. package/src/service/UserAccountService.ts +107 -0
  458. package/src/service/UserSessionService.ts +157 -0
  459. package/src/service/VisitStatService.ts +166 -0
  460. package/src/service/WorkbenchService.ts +220 -0
  461. package/src/service/anyapi/AnyApiSandboxService.ts +121 -0
  462. package/src/service/anyapi/AnyApiService.ts +186 -0
  463. package/src/service/asyncTask/AsyncTaskRunnerService.ts +319 -0
  464. package/src/service/asyncTask/AsyncTaskService.ts +21 -0
  465. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  466. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
  467. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +159 -0
  468. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +158 -0
  469. package/src/service/base/ApiBaseService.ts +42 -0
  470. package/src/service/base/ApiRateLimiter.ts +59 -0
  471. package/src/service/base/BaseService.ts +95 -0
  472. package/src/service/base/RedisCacheService.ts +42 -0
  473. package/src/service/crudstd/CrudStdActionService.ts +27 -0
  474. package/src/service/crudstd/CrudStdConstant.ts +62 -0
  475. package/src/service/crudstd/CrudStdRelationService.ts +118 -0
  476. package/src/service/crudstd/CrudStdService.ts +462 -0
  477. package/src/service/curd/CrudProQuick.ts +170 -0
  478. package/src/service/curd/CurdMixByAccountService.ts +89 -0
  479. package/src/service/curd/CurdMixByDictService.ts +114 -0
  480. package/src/service/curd/CurdMixByLinkToCustomService.ts +219 -0
  481. package/src/service/curd/CurdMixBySysConfigService.ts +78 -0
  482. package/src/service/curd/CurdMixByWorkbenchService.ts +71 -0
  483. package/src/service/curd/CurdMixService.ts +97 -0
  484. package/src/service/curd/CurdMixUtils.ts +314 -0
  485. package/src/service/curd/CurdProService.ts +231 -0
  486. package/src/service/curd/fixCfgModel.ts +120 -0
  487. package/src/service/proxyapi/ProxyApiLoadService.ts +170 -0
  488. package/src/service/proxyapi/ProxyApiService.ts +298 -0
  489. package/src/service/proxyapi/ProxyApiUtils.ts +32 -0
  490. package/src/service/proxyapi/RouteHandler.ts +8 -0
  491. package/src/service/proxyapi/RouteTrie.ts +74 -0
  492. package/src/service/proxyapi/WeightedRandom.ts +37 -0
  493. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -0
  494. package/src/views/404_app.html +31 -0
  495. package/src/views/404_workbench.html +34 -0
  496. package/src/views/static/favicon.ico +0 -0
  497. package/tsconfig.json +32 -32
@@ -0,0 +1,406 @@
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
+ }
@@ -0,0 +1,78 @@
1
+ import { Inject, Controller, Post } from '@midwayjs/core';
2
+ import { Context } from '@midwayjs/koa';
3
+ import { KeysOfSimpleSQL, KeysOfValidators } from '@/libs/crud-pro/models/keys';
4
+ import { BaseApiController } from '../base/BaseApiController';
5
+ import { checkPermission } from '@/middleware/permission.middleware';
6
+ import { SystemFuncCode } from '@/models/SystemPerm';
7
+
8
+ @Controller('/ns/api/manage/dataDict', { middleware: [checkPermission(SystemFuncCode.DataDictMangeRead)] })
9
+ export class DataDictManageApi extends BaseApiController {
10
+ @Inject()
11
+ protected ctx: Context;
12
+
13
+ @Post('/getDataDictList')
14
+ async getDataDictList() {
15
+ return this.executeSysSimpleSQL('sys_data_dict', KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
16
+ }
17
+
18
+ @Post('/getDataDictOne')
19
+ async getDataDictOne() {
20
+ return this.executeSysSimpleSQL('sys_data_dict', KeysOfSimpleSQL.SIMPLE_QUERY_ONE);
21
+ }
22
+
23
+ @Post('/createDataDict', { middleware: [checkPermission(SystemFuncCode.DataDictMangeWrite)] })
24
+ async createDataDict() {
25
+ return this.executeSysSimpleSQL('sys_data_dict', KeysOfSimpleSQL.SIMPLE_INSERT, {
26
+ validateCfg: {
27
+ 'data.dict_code': [KeysOfValidators.REQUIRED],
28
+ },
29
+ });
30
+ }
31
+
32
+ @Post('/updateDataDict', { middleware: [checkPermission(SystemFuncCode.DataDictMangeWrite)] })
33
+ async updateDataDict() {
34
+ return this.executeSysSimpleSQL('sys_data_dict', KeysOfSimpleSQL.SIMPLE_UPDATE, {
35
+ validateCfg: {
36
+ 'condition.id': [KeysOfValidators.REQUIRED, KeysOfValidators.NUMERIC],
37
+ },
38
+ });
39
+ }
40
+
41
+ @Post('/deleteDataDict', { middleware: [checkPermission(SystemFuncCode.DataDictMangeWrite)] })
42
+ async deleteDataDict() {
43
+ return this.executeSysSimpleSQL('sys_data_dict', KeysOfSimpleSQL.SIMPLE_DELETE, {
44
+ validateCfg: {
45
+ 'condition.dict_code': [KeysOfValidators.REQUIRED],
46
+ },
47
+ });
48
+ }
49
+
50
+ @Post('/getDataDictItemList')
51
+ async getDataDictItemList() {
52
+ return this.executeSysSimpleSQL('sys_data_dict_item', KeysOfSimpleSQL.SIMPLE_QUERY_PAGE);
53
+ }
54
+
55
+ @Post('/getDataDictItemOne')
56
+ async getDataDictItemOne() {
57
+ return this.executeSysSimpleSQL('sys_data_dict_item', KeysOfSimpleSQL.SIMPLE_QUERY_ONE);
58
+ }
59
+
60
+ @Post('/createDataDictItem', { middleware: [checkPermission(SystemFuncCode.DataDictMangeWrite)] })
61
+ async createDataDictItem() {
62
+ return this.executeSysSimpleSQL('sys_data_dict_item', KeysOfSimpleSQL.SIMPLE_INSERT);
63
+ }
64
+
65
+ @Post('/updateDataDictItem', { middleware: [checkPermission(SystemFuncCode.DataDictMangeWrite)] })
66
+ async updateDataDictItem() {
67
+ return this.executeSysSimpleSQL('sys_data_dict_item', KeysOfSimpleSQL.SIMPLE_UPDATE);
68
+ }
69
+
70
+ @Post('/deleteDataDictItem', { middleware: [checkPermission(SystemFuncCode.DataDictMangeWrite)] })
71
+ async deleteDataDictItem() {
72
+ return this.executeSysSimpleSQL('sys_data_dict_item', KeysOfSimpleSQL.SIMPLE_DELETE, {
73
+ validateCfg: {
74
+ 'condition.dict_code': [KeysOfValidators.REQUIRED],
75
+ },
76
+ });
77
+ }
78
+ }
@@ -0,0 +1,175 @@
1
+ import { Controller, Fields, Files, Inject, Post, Query } from '@midwayjs/core';
2
+ import { Context } from '@midwayjs/koa';
3
+ import { BaseApiController } from '../base/BaseApiController';
4
+ import { checkPermission } from '../../middleware/permission.middleware';
5
+ import { SystemFuncCode } from '../../models/SystemPerm';
6
+ import { CommonResult } from '../../libs/utils/common-dto';
7
+ import { AccessType, UploadCategoryType } from '../../models/bizmodels';
8
+ import { BizException } from '../../models/devops';
9
+ import { FileCenterService, toDownloadPaths } from '../../service/FileCenterService';
10
+ import { SystemTables } from '../../models/SystemTables';
11
+ import { KeysOfSimpleSQL } from '../../libs/crud-pro/models/keys';
12
+ import { WorkbenchService } from '../../service/WorkbenchService';
13
+ import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
14
+
15
+ interface IReleaseAssetsParams {
16
+ cdnResources: any[];
17
+ packageName: string;
18
+ packageVersion: string;
19
+ }
20
+
21
+ function toAssetsSchema(fileList: any) {
22
+ for (let i = 0; i < fileList.length; i++) {
23
+ const fileListElement = fileList[i];
24
+ fileListElement.settingKey = 'assets' + i;
25
+ }
26
+ return {
27
+ schema: [
28
+ {
29
+ title: '资源配置',
30
+ name: 'fileList',
31
+ type: 'array',
32
+ properties: {
33
+ fileUrl: { label: '文件URL', component: 'Input', xProps: { hasClear: true }, width: 500 },
34
+ fileType: {
35
+ label: '文件类型',
36
+ component: 'Select',
37
+ enums: [
38
+ { label: 'js', value: 'js' },
39
+ { label: 'css', value: 'css' },
40
+ ],
41
+ xProps: {
42
+ hasClear: true,
43
+ },
44
+ width: 500,
45
+ },
46
+ isModule: {
47
+ label: 'isModule',
48
+ component: 'Select',
49
+ enums: [
50
+ { label: 'true', value: true },
51
+ { label: 'false', value: false },
52
+ ],
53
+ xProps: {
54
+ hasClear: true,
55
+ },
56
+ width: 500,
57
+ },
58
+ },
59
+ },
60
+ ],
61
+ data: {
62
+ fileList: fileList,
63
+ },
64
+ };
65
+ }
66
+
67
+ @Controller('/ns/api/manage/deploy', { middleware: [checkPermission([SystemFuncCode.AppMangeRead, SystemFuncCode.WorkbenchMangeRead])] })
68
+ export class DeployManageApi extends BaseApiController {
69
+ @Inject()
70
+ protected ctx: Context;
71
+
72
+ @Inject()
73
+ private fileCenterService: FileCenterService;
74
+
75
+ @Inject()
76
+ private workbenchService: WorkbenchService;
77
+
78
+ /**
79
+ * 资源文件上传
80
+ * @param files
81
+ * @param fields
82
+ * @param queryData
83
+ */
84
+ @Post('/uploadAssets', { middleware: [checkPermission(SystemFuncCode.AppMangeWrite)] })
85
+ async uploadAssets(@Files() files, @Fields() fields, @Query() queryData): Promise<CommonResult> {
86
+ const accessType = AccessType.open;
87
+ const referer = this.ctx.req.headers.referer;
88
+
89
+ if (!fields.uploadPath) {
90
+ throw new BizException('uploadPath不能为空');
91
+ }
92
+
93
+ const { fileKey, filename, storageUrl } = await this.fileCenterService.uploadFileToOSS(files, accessType, referer, {
94
+ uploadCategoryType: UploadCategoryType.assets,
95
+ uploadPath: fields.uploadPath,
96
+ });
97
+
98
+ const origin = this.ctx.request.origin;
99
+
100
+ const downloadUrls = toDownloadPaths(origin, fileKey);
101
+ const data = {
102
+ fileKey,
103
+ filename,
104
+ storageUrl,
105
+ ...downloadUrls,
106
+ };
107
+ return CommonResult.successRes(data);
108
+ }
109
+
110
+ /**
111
+ * 资源文件让其生效
112
+ */
113
+ @Post('/releaseAssets', { middleware: [checkPermission(SystemFuncCode.AppMangeWrite)] })
114
+ async releaseAssets(): Promise<CommonResult> {
115
+ const params = this.ctx.request.body as IReleaseAssetsParams;
116
+ if (!params.packageName) {
117
+ throw new BizException('packageName参数不存在');
118
+ }
119
+
120
+ if (params.packageName.length < 5) {
121
+ throw new BizException('packageName参数小于5');
122
+ }
123
+
124
+ const cdnResources = params.cdnResources;
125
+ if (!Array.isArray(cdnResources) || cdnResources.length === 0) {
126
+ throw new BizException('cdnResources参数不存在');
127
+ }
128
+
129
+ const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
130
+
131
+ const workbench = await this.curdMixService.executeCrudByCfg(
132
+ {
133
+ data: {
134
+ package_assets: JSON.stringify(toAssetsSchema(cdnResources)),
135
+ },
136
+ condition: {
137
+ package_name: params.packageName,
138
+ },
139
+ },
140
+ {
141
+ sqlTable: SystemTables.sys_workbench,
142
+ sqlDatabase: SystemDbName,
143
+ sqlDbType: SystemDbType,
144
+ sqlSimpleName: KeysOfSimpleSQL.SIMPLE_UPDATE,
145
+ }
146
+ );
147
+
148
+ const app = await this.curdMixService.executeCrudByCfg(
149
+ {
150
+ data: {
151
+ package_assets: JSON.stringify(toAssetsSchema(cdnResources)),
152
+ },
153
+ condition: {
154
+ package_name: params.packageName,
155
+ },
156
+ },
157
+ {
158
+ sqlTable: SystemTables.sys_app,
159
+ sqlDatabase: SystemDbName,
160
+ sqlDbType: SystemDbType,
161
+ sqlSimpleName: KeysOfSimpleSQL.SIMPLE_UPDATE,
162
+ }
163
+ );
164
+
165
+ this.workbenchService.clearCache();
166
+
167
+ const workbenchAffected = workbench.getResModelItem('affected') || {};
168
+ const appAffected = app.getResModelItem('affected') || {};
169
+
170
+ const result = CommonResult.successRes({ workbenchAffected, appAffected });
171
+
172
+ result.message = `${cdnResources.length}个文件,更新到${workbenchAffected.affectedRows}个站点模版;更新到${appAffected.affectedRows}个应用模版,`;
173
+ return result;
174
+ }
175
+ }