midway-fatcms 0.0.1-beta.29 → 0.0.1-beta.30

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 (329) hide show
  1. package/.eslintrc.json +14 -14
  2. package/.prettierrc.js +4 -4
  3. package/README.md +8 -8
  4. package/index.d.ts +10 -10
  5. package/package.json +76 -76
  6. package/tsconfig.json +32 -32
  7. package/dist/config/config.default.d.ts +0 -3
  8. package/dist/config/config.default.js +0 -189
  9. package/dist/config/seed/aeskey.txt +0 -1
  10. package/dist/config/utils.d.ts +0 -1
  11. package/dist/config/utils.js +0 -23
  12. package/dist/configuration.d.ts +0 -7
  13. package/dist/configuration.js +0 -113
  14. package/dist/controller/base/BaseApiController.d.ts +0 -37
  15. package/dist/controller/base/BaseApiController.js +0 -164
  16. package/dist/controller/gateway/AnyApiGatewayController.d.ts +0 -13
  17. package/dist/controller/gateway/AnyApiGatewayController.js +0 -55
  18. package/dist/controller/gateway/AsyncTaskController.d.ts +0 -20
  19. package/dist/controller/gateway/AsyncTaskController.js +0 -181
  20. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +0 -21
  21. package/dist/controller/gateway/CrudMtdGatewayController.js +0 -119
  22. package/dist/controller/gateway/CrudStdGatewayController.d.ts +0 -38
  23. package/dist/controller/gateway/CrudStdGatewayController.js +0 -137
  24. package/dist/controller/gateway/DocGatewayController.d.ts +0 -27
  25. package/dist/controller/gateway/DocGatewayController.js +0 -179
  26. package/dist/controller/gateway/FileController.d.ts +0 -25
  27. package/dist/controller/gateway/FileController.js +0 -129
  28. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +0 -18
  29. package/dist/controller/gateway/ProxyApiGatewayController.js +0 -78
  30. package/dist/controller/gateway/PublicApiController.d.ts +0 -27
  31. package/dist/controller/gateway/PublicApiController.js +0 -165
  32. package/dist/controller/gateway/StaticController.d.ts +0 -24
  33. package/dist/controller/gateway/StaticController.js +0 -288
  34. package/dist/controller/helpers.controller.d.ts +0 -39
  35. package/dist/controller/helpers.controller.js +0 -188
  36. package/dist/controller/home.controller.d.ts +0 -9
  37. package/dist/controller/home.controller.js +0 -72
  38. package/dist/controller/manage/AnyApiMangeApi.d.ts +0 -10
  39. package/dist/controller/manage/AnyApiMangeApi.js +0 -98
  40. package/dist/controller/manage/AppLogMangeApi.d.ts +0 -10
  41. package/dist/controller/manage/AppLogMangeApi.js +0 -88
  42. package/dist/controller/manage/AppMangeApi.d.ts +0 -10
  43. package/dist/controller/manage/AppMangeApi.js +0 -88
  44. package/dist/controller/manage/AppPageMangeApi.d.ts +0 -10
  45. package/dist/controller/manage/AppPageMangeApi.js +0 -87
  46. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +0 -10
  47. package/dist/controller/manage/AppSchemaHistoryApi.js +0 -83
  48. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +0 -10
  49. package/dist/controller/manage/CrudMethodsMangeApi.js +0 -84
  50. package/dist/controller/manage/CrudStandardDesignApi.d.ts +0 -38
  51. package/dist/controller/manage/CrudStandardDesignApi.js +0 -342
  52. package/dist/controller/manage/DataDictManageApi.d.ts +0 -15
  53. package/dist/controller/manage/DataDictManageApi.js +0 -133
  54. package/dist/controller/manage/DeployManageApi.d.ts +0 -19
  55. package/dist/controller/manage/DeployManageApi.js +0 -180
  56. package/dist/controller/manage/DocLibManageApi.d.ts +0 -10
  57. package/dist/controller/manage/DocLibManageApi.js +0 -104
  58. package/dist/controller/manage/DocManageApi.d.ts +0 -11
  59. package/dist/controller/manage/DocManageApi.js +0 -130
  60. package/dist/controller/manage/FileManageApi.d.ts +0 -13
  61. package/dist/controller/manage/FileManageApi.js +0 -77
  62. package/dist/controller/manage/LowCodeTplManageApi.d.ts +0 -13
  63. package/dist/controller/manage/LowCodeTplManageApi.js +0 -86
  64. package/dist/controller/manage/MenuManageApi.d.ts +0 -10
  65. package/dist/controller/manage/MenuManageApi.js +0 -93
  66. package/dist/controller/manage/ProxyApiMangeApi.d.ts +0 -10
  67. package/dist/controller/manage/ProxyApiMangeApi.js +0 -87
  68. package/dist/controller/manage/SuperAdminManageApi.d.ts +0 -24
  69. package/dist/controller/manage/SuperAdminManageApi.js +0 -153
  70. package/dist/controller/manage/SysConfigMangeApi.d.ts +0 -11
  71. package/dist/controller/manage/SysConfigMangeApi.js +0 -126
  72. package/dist/controller/manage/SystemInfoManageApi.d.ts +0 -12
  73. package/dist/controller/manage/SystemInfoManageApi.js +0 -72
  74. package/dist/controller/manage/UserAccountManageApi.d.ts +0 -14
  75. package/dist/controller/manage/UserAccountManageApi.js +0 -129
  76. package/dist/controller/manage/WorkbenchMangeApi.d.ts +0 -11
  77. package/dist/controller/manage/WorkbenchMangeApi.js +0 -103
  78. package/dist/controller/myinfo/AuthController.d.ts +0 -33
  79. package/dist/controller/myinfo/AuthController.js +0 -136
  80. package/dist/controller/myinfo/MyInfoController.d.ts +0 -13
  81. package/dist/controller/myinfo/MyInfoController.js +0 -51
  82. package/dist/controller/render/AppRenderController.d.ts +0 -11
  83. package/dist/controller/render/AppRenderController.js +0 -92
  84. package/dist/controller/test.controller.d.ts +0 -8
  85. package/dist/controller/test.controller.js +0 -51
  86. package/dist/filter/default.filter.d.ts +0 -7
  87. package/dist/filter/default.filter.js +0 -23
  88. package/dist/filter/notfound.filter.d.ts +0 -5
  89. package/dist/filter/notfound.filter.js +0 -20
  90. package/dist/index.d.ts +0 -102
  91. package/dist/index.js +0 -120
  92. package/dist/interface.d.ts +0 -27
  93. package/dist/interface.js +0 -3
  94. package/dist/libs/crud-pro/CrudPro.d.ts +0 -37
  95. package/dist/libs/crud-pro/CrudPro.js +0 -136
  96. package/dist/libs/crud-pro/defaultConfigs.d.ts +0 -4
  97. package/dist/libs/crud-pro/defaultConfigs.js +0 -15
  98. package/dist/libs/crud-pro/exceptions.d.ts +0 -104
  99. package/dist/libs/crud-pro/exceptions.js +0 -117
  100. package/dist/libs/crud-pro/interfaces.d.ts +0 -163
  101. package/dist/libs/crud-pro/interfaces.js +0 -12
  102. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +0 -49
  103. package/dist/libs/crud-pro/models/ExecuteContext.js +0 -79
  104. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +0 -38
  105. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +0 -72
  106. package/dist/libs/crud-pro/models/FuncContext.d.ts +0 -18
  107. package/dist/libs/crud-pro/models/FuncContext.js +0 -6
  108. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +0 -65
  109. package/dist/libs/crud-pro/models/RequestCfgModel.js +0 -81
  110. package/dist/libs/crud-pro/models/RequestModel.d.ts +0 -25
  111. package/dist/libs/crud-pro/models/RequestModel.js +0 -113
  112. package/dist/libs/crud-pro/models/ResModel.d.ts +0 -16
  113. package/dist/libs/crud-pro/models/ResModel.js +0 -2
  114. package/dist/libs/crud-pro/models/ServiceHub.d.ts +0 -20
  115. package/dist/libs/crud-pro/models/ServiceHub.js +0 -2
  116. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +0 -22
  117. package/dist/libs/crud-pro/models/SqlCfgModel.js +0 -40
  118. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +0 -6
  119. package/dist/libs/crud-pro/models/SqlSegArg.js +0 -12
  120. package/dist/libs/crud-pro/models/Transaction.d.ts +0 -29
  121. package/dist/libs/crud-pro/models/Transaction.js +0 -67
  122. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +0 -28
  123. package/dist/libs/crud-pro/models/TransactionMySQL.js +0 -76
  124. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +0 -28
  125. package/dist/libs/crud-pro/models/TransactionPostgres.js +0 -85
  126. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +0 -34
  127. package/dist/libs/crud-pro/models/TransactionSqlServer.js +0 -92
  128. package/dist/libs/crud-pro/models/keys.d.ts +0 -106
  129. package/dist/libs/crud-pro/models/keys.js +0 -149
  130. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +0 -11
  131. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +0 -73
  132. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +0 -9
  133. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +0 -112
  134. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +0 -17
  135. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +0 -225
  136. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +0 -9
  137. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +0 -51
  138. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +0 -13
  139. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +0 -148
  140. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +0 -24
  141. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +0 -340
  142. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +0 -25
  143. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +0 -165
  144. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +0 -32
  145. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +0 -334
  146. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +0 -24
  147. package/dist/libs/crud-pro/services/CrudProServiceBase.js +0 -79
  148. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +0 -9
  149. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +0 -78
  150. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +0 -32
  151. package/dist/libs/crud-pro/services/CurdProServiceHub.js +0 -64
  152. package/dist/libs/crud-pro/sql.txt +0 -120
  153. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +0 -9
  154. package/dist/libs/crud-pro/utils/CompareUtils.js +0 -25
  155. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +0 -9
  156. package/dist/libs/crud-pro/utils/DatabaseName.js +0 -50
  157. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +0 -7
  158. package/dist/libs/crud-pro/utils/DateTimeUtils.js +0 -21
  159. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +0 -19
  160. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +0 -47
  161. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +0 -5
  162. package/dist/libs/crud-pro/utils/MessageParseUtils.js +0 -33
  163. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +0 -39
  164. package/dist/libs/crud-pro/utils/MixinUtils.js +0 -255
  165. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +0 -11
  166. package/dist/libs/crud-pro/utils/ModelUtils.js +0 -49
  167. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +0 -11
  168. package/dist/libs/crud-pro/utils/MultiKeyMap.js +0 -63
  169. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +0 -5
  170. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +0 -29
  171. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +0 -40
  172. package/dist/libs/crud-pro/utils/TypeUtils.js +0 -166
  173. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +0 -3
  174. package/dist/libs/crud-pro/utils/ValidateUtils.js +0 -165
  175. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +0 -3
  176. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +0 -19
  177. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +0 -3
  178. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +0 -20
  179. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +0 -3
  180. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +0 -20
  181. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +0 -4
  182. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +0 -21
  183. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +0 -3
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +0 -22
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +0 -2
  186. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +0 -11
  187. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +0 -2
  188. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +0 -11
  189. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +0 -2
  190. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +0 -128
  191. package/dist/libs/global-config/global-config.d.ts +0 -45
  192. package/dist/libs/global-config/global-config.js +0 -33
  193. package/dist/libs/utils/common-dto.d.ts +0 -18
  194. package/dist/libs/utils/common-dto.js +0 -40
  195. package/dist/libs/utils/crypto-utils.d.ts +0 -3
  196. package/dist/libs/utils/crypto-utils.js +0 -46
  197. package/dist/libs/utils/errorToString.d.ts +0 -2
  198. package/dist/libs/utils/errorToString.js +0 -57
  199. package/dist/libs/utils/fatcms-request.d.ts +0 -30
  200. package/dist/libs/utils/fatcms-request.js +0 -104
  201. package/dist/libs/utils/functions.d.ts +0 -5
  202. package/dist/libs/utils/functions.js +0 -68
  203. package/dist/libs/utils/ordernum-utils.d.ts +0 -2
  204. package/dist/libs/utils/ordernum-utils.js +0 -13
  205. package/dist/libs/utils/parseConfig.d.ts +0 -7
  206. package/dist/libs/utils/parseConfig.js +0 -44
  207. package/dist/libs/utils/parseCreateSql.d.ts +0 -5
  208. package/dist/libs/utils/parseCreateSql.js +0 -86
  209. package/dist/libs/utils/render-utils.d.ts +0 -28
  210. package/dist/libs/utils/render-utils.js +0 -135
  211. package/dist/middleware/forbidden.middleware.d.ts +0 -10
  212. package/dist/middleware/forbidden.middleware.js +0 -54
  213. package/dist/middleware/global.middleware.d.ts +0 -10
  214. package/dist/middleware/global.middleware.js +0 -266
  215. package/dist/middleware/permission.middleware.d.ts +0 -18
  216. package/dist/middleware/permission.middleware.js +0 -74
  217. package/dist/middleware/tx.middleware.d.ts +0 -9
  218. package/dist/middleware/tx.middleware.js +0 -40
  219. package/dist/models/AsyncTaskModel.d.ts +0 -74
  220. package/dist/models/AsyncTaskModel.js +0 -31
  221. package/dist/models/RedisKeys.d.ts +0 -14
  222. package/dist/models/RedisKeys.js +0 -17
  223. package/dist/models/SystemEntities.d.ts +0 -98
  224. package/dist/models/SystemEntities.js +0 -2
  225. package/dist/models/SystemPerm.d.ts +0 -95
  226. package/dist/models/SystemPerm.js +0 -100
  227. package/dist/models/SystemTables.d.ts +0 -25
  228. package/dist/models/SystemTables.js +0 -28
  229. package/dist/models/bizmodels.d.ts +0 -97
  230. package/dist/models/bizmodels.js +0 -39
  231. package/dist/models/contextLogger.d.ts +0 -25
  232. package/dist/models/contextLogger.js +0 -112
  233. package/dist/models/devops.d.ts +0 -12
  234. package/dist/models/devops.js +0 -19
  235. package/dist/models/userSession.d.ts +0 -61
  236. package/dist/models/userSession.js +0 -165
  237. package/dist/schedule/anonymousContext.d.ts +0 -14
  238. package/dist/schedule/anonymousContext.js +0 -59
  239. package/dist/schedule/index.d.ts +0 -4
  240. package/dist/schedule/index.js +0 -10
  241. package/dist/schedule/runSchedule.d.ts +0 -12
  242. package/dist/schedule/runSchedule.js +0 -68
  243. package/dist/schedule/scheduleNames.d.ts +0 -13
  244. package/dist/schedule/scheduleNames.js +0 -17
  245. package/dist/service/AuthService.d.ts +0 -70
  246. package/dist/service/AuthService.js +0 -251
  247. package/dist/service/EnumInfoService.d.ts +0 -30
  248. package/dist/service/EnumInfoService.js +0 -127
  249. package/dist/service/FileCenterService.d.ts +0 -43
  250. package/dist/service/FileCenterService.js +0 -351
  251. package/dist/service/SysConfigService.d.ts +0 -7
  252. package/dist/service/SysConfigService.js +0 -47
  253. package/dist/service/UserAccountService.d.ts +0 -23
  254. package/dist/service/UserAccountService.js +0 -107
  255. package/dist/service/UserSessionService.d.ts +0 -37
  256. package/dist/service/UserSessionService.js +0 -156
  257. package/dist/service/VisitStatService.d.ts +0 -14
  258. package/dist/service/VisitStatService.js +0 -158
  259. package/dist/service/WorkbenchService.d.ts +0 -52
  260. package/dist/service/WorkbenchService.js +0 -202
  261. package/dist/service/anyapi/AnyApiSandboxService.d.ts +0 -15
  262. package/dist/service/anyapi/AnyApiSandboxService.js +0 -122
  263. package/dist/service/anyapi/AnyApiService.d.ts +0 -27
  264. package/dist/service/anyapi/AnyApiService.js +0 -181
  265. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +0 -50
  266. package/dist/service/asyncTask/AsyncTaskRunnerService.js +0 -287
  267. package/dist/service/asyncTask/AsyncTaskService.d.ts +0 -7
  268. package/dist/service/asyncTask/AsyncTaskService.js +0 -34
  269. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +0 -10
  270. package/dist/service/asyncTask/handler/ExcelInfoModel.js +0 -2
  271. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +0 -7
  272. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +0 -216
  273. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +0 -36
  274. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +0 -139
  275. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +0 -46
  276. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +0 -121
  277. package/dist/service/base/ApiBaseService.d.ts +0 -15
  278. package/dist/service/base/ApiBaseService.js +0 -50
  279. package/dist/service/base/ApiRateLimiter.d.ts +0 -10
  280. package/dist/service/base/ApiRateLimiter.js +0 -51
  281. package/dist/service/base/BaseService.d.ts +0 -41
  282. package/dist/service/base/BaseService.js +0 -101
  283. package/dist/service/base/RedisCacheService.d.ts +0 -20
  284. package/dist/service/base/RedisCacheService.js +0 -57
  285. package/dist/service/crudstd/CrudStdActionService.d.ts +0 -17
  286. package/dist/service/crudstd/CrudStdActionService.js +0 -32
  287. package/dist/service/crudstd/CrudStdConstant.d.ts +0 -58
  288. package/dist/service/crudstd/CrudStdConstant.js +0 -64
  289. package/dist/service/crudstd/CrudStdRelationService.d.ts +0 -10
  290. package/dist/service/crudstd/CrudStdRelationService.js +0 -85
  291. package/dist/service/crudstd/CrudStdService.d.ts +0 -57
  292. package/dist/service/crudstd/CrudStdService.js +0 -239
  293. package/dist/service/curd/CrudProQuick.d.ts +0 -24
  294. package/dist/service/curd/CrudProQuick.js +0 -109
  295. package/dist/service/curd/CurdMixByAccountService.d.ts +0 -9
  296. package/dist/service/curd/CurdMixByAccountService.js +0 -93
  297. package/dist/service/curd/CurdMixByDictService.d.ts +0 -13
  298. package/dist/service/curd/CurdMixByDictService.js +0 -114
  299. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +0 -31
  300. package/dist/service/curd/CurdMixByLinkToCustomService.js +0 -203
  301. package/dist/service/curd/CurdMixBySysConfigService.d.ts +0 -9
  302. package/dist/service/curd/CurdMixBySysConfigService.js +0 -80
  303. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +0 -10
  304. package/dist/service/curd/CurdMixByWorkbenchService.js +0 -78
  305. package/dist/service/curd/CurdMixService.d.ts +0 -27
  306. package/dist/service/curd/CurdMixService.js +0 -100
  307. package/dist/service/curd/CurdMixUtils.d.ts +0 -51
  308. package/dist/service/curd/CurdMixUtils.js +0 -275
  309. package/dist/service/curd/CurdProService.d.ts +0 -32
  310. package/dist/service/curd/CurdProService.js +0 -210
  311. package/dist/service/curd/fixCfgModel.d.ts +0 -3
  312. package/dist/service/curd/fixCfgModel.js +0 -107
  313. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +0 -21
  314. package/dist/service/proxyapi/ProxyApiLoadService.js +0 -167
  315. package/dist/service/proxyapi/ProxyApiService.d.ts +0 -60
  316. package/dist/service/proxyapi/ProxyApiService.js +0 -260
  317. package/dist/service/proxyapi/ProxyApiUtils.d.ts +0 -15
  318. package/dist/service/proxyapi/ProxyApiUtils.js +0 -34
  319. package/dist/service/proxyapi/RouteHandler.d.ts +0 -5
  320. package/dist/service/proxyapi/RouteHandler.js +0 -9
  321. package/dist/service/proxyapi/RouteTrie.d.ts +0 -12
  322. package/dist/service/proxyapi/RouteTrie.js +0 -63
  323. package/dist/service/proxyapi/WeightedRandom.d.ts +0 -9
  324. package/dist/service/proxyapi/WeightedRandom.js +0 -31
  325. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +0 -8
  326. package/dist/service/proxyapi/WeightedRoundRobin.js +0 -32
  327. package/dist/views/404_app.html +0 -31
  328. package/dist/views/404_workbench.html +0 -34
  329. package/dist/views/static/favicon.ico +0 -0
@@ -1,334 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CrudProOriginToExecuteSql = void 0;
4
- const CrudProServiceBase_1 = require("./CrudProServiceBase");
5
- const MixinUtils_1 = require("../utils/MixinUtils");
6
- const SqlSegArg_1 = require("../models/SqlSegArg");
7
- const keys_1 = require("../models/keys");
8
- const exceptions_1 = require("../exceptions");
9
- const ModelUtils_1 = require("../utils/ModelUtils");
10
- const FuncContext_1 = require("../models/FuncContext");
11
- const TypeUtils_1 = require("../utils/TypeUtils");
12
- const SqlFuncUtils_1 = require("../utils/SqlFuncUtils");
13
- const convertColumnName_1 = require("../utils/sqlConvert/convertColumnName");
14
- const CrudProGenSqlCondition_1 = require("./CrudProGenSqlCondition");
15
- const KEYS_CUSTOM_PATTERN = /@@[0-9a-zA-Z:._]+/gm;
16
- /**
17
- * 存在任何需要排除的
18
- * @param columns
19
- */
20
- function isAnyStartWithExclude(columns) {
21
- if (MixinUtils_1.MixinUtils.isEmpty(columns)) {
22
- return false;
23
- }
24
- for (let i = 0; i < columns.length; i++) {
25
- const s = columns[i];
26
- if (s.startsWith('!')) {
27
- return true;
28
- }
29
- }
30
- return false;
31
- }
32
- class CrudProOriginToExecuteSql extends CrudProServiceBase_1.CrudProServiceBase {
33
- async convertOriginToExecuteSql(sqlCfgModel) {
34
- const originSql = sqlCfgModel.originSql;
35
- if (MixinUtils_1.MixinUtils.isEmpty(originSql)) {
36
- // 允许配置中没有originSql,此时可能仅仅用来做校验逻辑
37
- return;
38
- }
39
- if (MixinUtils_1.MixinUtils.isNotEmpty(sqlCfgModel.executeSql)) {
40
- //直接传递可执行SQL ,不需要再转换。
41
- return;
42
- }
43
- const sqlArgModelMap = await this.generateWordMap(originSql, sqlCfgModel);
44
- const argList = [];
45
- let executeSql = originSql;
46
- // 发现有需要被替换的变量。
47
- if (sqlArgModelMap) {
48
- executeSql = originSql.replace(KEYS_CUSTOM_PATTERN, word => {
49
- if (!word) {
50
- return '';
51
- }
52
- const sqlArgModel = sqlArgModelMap[word];
53
- if (!sqlArgModel) {
54
- return '';
55
- }
56
- if (MixinUtils_1.MixinUtils.isNotEmpty(sqlArgModel.args) && Array.isArray(sqlArgModel.args)) {
57
- argList.push(...sqlArgModel.args);
58
- }
59
- return sqlArgModel.sql;
60
- });
61
- }
62
- sqlCfgModel.executeSqlArgs = argList;
63
- sqlCfgModel.executeSql = executeSql;
64
- }
65
- async generateWordMap(originSql, sqlCfgModel) {
66
- // ['@@columns', '@@table', '@@asWhere:condition', '@@orderBys']
67
- const sqlKeywords = originSql.match(KEYS_CUSTOM_PATTERN);
68
- // 没有需要被替换的变量。
69
- if (!sqlKeywords || sqlKeywords.length === 0) {
70
- return null;
71
- }
72
- const sqlKeywordArgModelMap = {};
73
- for (let i = 0; i < sqlKeywords.length; i++) {
74
- const word = sqlKeywords[i]; // @@columns
75
- if (word) {
76
- const sqlArgModel = await this.generateWord(word, sqlCfgModel);
77
- if (sqlArgModel) {
78
- sqlKeywordArgModelMap[word] = sqlArgModel;
79
- }
80
- }
81
- }
82
- return sqlKeywordArgModelMap;
83
- }
84
- async generateWord(word, sqlCfg) {
85
- const exeCtx = this.getExecuteContext();
86
- const reqCfg = exeCtx.getCfgModel();
87
- const reqModel = exeCtx.getReqModel();
88
- if (word === keys_1.KeysOfCustomSQL.SQL_TABLE) {
89
- return this.generateTable(reqCfg, sqlCfg);
90
- }
91
- else if (word === keys_1.KeysOfCustomSQL.SQL_COLUMNS) {
92
- return this.generateColumns(reqCfg, sqlCfg, reqModel);
93
- }
94
- else if (word.startsWith(keys_1.KeysOfCustomSQL.SQL_AS_WHERE)) {
95
- return this.generateCondition(reqModel, sqlCfg, MixinUtils_1.MixinUtils.removeStringPrefix(word, keys_1.KeysOfCustomSQL.SQL_AS_WHERE));
96
- }
97
- else if (word === keys_1.KeysOfCustomSQL.SQL_OFFSET_LIMIT) {
98
- return this.generateOffsetLimit(reqCfg, sqlCfg, reqModel);
99
- }
100
- else if (word === keys_1.KeysOfCustomSQL.SQL_ORDER_BYS) {
101
- return this.generateOrderBys(reqModel, sqlCfg);
102
- }
103
- else if ((word.startsWith(keys_1.KeysOfCustomSQL.SQL_GET_DATA_ATTR_START) || word.startsWith(keys_1.KeysOfCustomSQL.SQL_GET_CONDITION_ATTR_START)) && word.indexOf('.') > 0) {
104
- return this.generateGetAttr(reqModel, word); //// data.xxx, condition.xxx
105
- }
106
- else if (word.startsWith(keys_1.KeysOfCustomSQL.SQL_PICK_RES_AS_NUMBER) || word.startsWith(keys_1.KeysOfCustomSQL.SQL_PICK_RES_AS_STRING)) {
107
- return this.generatePickResAs(reqModel, word); // @@pickResAsNumber:replies_count
108
- }
109
- else if (word.startsWith(keys_1.KeysOfCustomSQL.SQL_AS_UPDATE)) {
110
- return this.generateDataUpdate(reqModel, sqlCfg, MixinUtils_1.MixinUtils.removeStringPrefix(word, keys_1.KeysOfCustomSQL.SQL_AS_UPDATE));
111
- }
112
- else if (word.startsWith(keys_1.KeysOfCustomSQL.SQL_AS_INSERT_KEYS)) {
113
- return this.generateDataAsInsertKeys(reqModel, sqlCfg, MixinUtils_1.MixinUtils.removeStringPrefix(word, keys_1.KeysOfCustomSQL.SQL_AS_INSERT_KEYS));
114
- }
115
- else if (word.startsWith(keys_1.KeysOfCustomSQL.SQL_AS_INSERT_VALUES)) {
116
- return this.generateDataAsInsertValues(reqModel, MixinUtils_1.MixinUtils.removeStringPrefix(word, keys_1.KeysOfCustomSQL.SQL_AS_INSERT_VALUES));
117
- }
118
- else if (word.startsWith(keys_1.KeysOfCustomSQL.SQL_FUNCTION)) {
119
- return this.generateSqlJavaFunction(reqCfg, MixinUtils_1.MixinUtils.removeStringPrefix(word, keys_1.KeysOfCustomSQL.SQL_FUNCTION));
120
- }
121
- else {
122
- return new SqlSegArg_1.SqlSegArg(word.toString());
123
- }
124
- }
125
- generateDataAsInsertKeys(req, sqlCfgModel, dataName) {
126
- const data = req.getCondOrDataJsonObject(dataName);
127
- if (MixinUtils_1.MixinUtils.isEmpty(data)) {
128
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_KEYS, dataName);
129
- }
130
- const keys = Object.keys(data).sort();
131
- const columnList = keys.map(columnName => {
132
- return (0, convertColumnName_1.toSqlColumnName)(columnName, sqlCfgModel);
133
- });
134
- const sql = columnList.join(','); // `column1`,`column2`,`column3`,
135
- return new SqlSegArg_1.SqlSegArg(sql); // 只有sql,没有arg
136
- }
137
- generateTable(requestCfg, sqlCfgModel) {
138
- const sqlTableName = ModelUtils_1.ModelUtils.getSqlTable(sqlCfgModel, requestCfg);
139
- if (MixinUtils_1.MixinUtils.isEmpty(sqlTableName)) {
140
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_EMPTY_TABLE_NAME);
141
- }
142
- const sqlSchema = ModelUtils_1.ModelUtils.getSqlSchema(sqlCfgModel, requestCfg);
143
- if (MixinUtils_1.MixinUtils.isNotEmpty(sqlSchema)) {
144
- return new SqlSegArg_1.SqlSegArg(`${(0, convertColumnName_1.toSqlColumnName)(sqlSchema, sqlCfgModel)}.${(0, convertColumnName_1.toSqlColumnName)(sqlTableName, sqlCfgModel)}`);
145
- }
146
- return new SqlSegArg_1.SqlSegArg((0, convertColumnName_1.toSqlColumnName)(sqlTableName, sqlCfgModel));
147
- }
148
- async generateColumns(cfg, sqlCfgModel, req) {
149
- // req 和 cfg 都没有 columns字段
150
- if (MixinUtils_1.MixinUtils.isEmpty(cfg.columns) && MixinUtils_1.MixinUtils.isEmpty(req.columns)) {
151
- return new SqlSegArg_1.SqlSegArg('*');
152
- }
153
- const cfgColumns = await this.generateCfgColumns(sqlCfgModel); // 不会为空
154
- const reqColumns = req.columns;
155
- // req 为空
156
- if (MixinUtils_1.MixinUtils.isEmpty(reqColumns)) {
157
- return new SqlSegArg_1.SqlSegArg((0, convertColumnName_1.toSqlColumnNamesJoin)(cfgColumns, sqlCfgModel));
158
- }
159
- // req 不为空:1. 排除法
160
- // cfgColumns与reqColumns 都不为空: 使用排除法
161
- if (isAnyStartWithExclude(reqColumns)) {
162
- const result = [];
163
- for (let i = 0; i < cfgColumns.length; i++) {
164
- const cfgColumn = cfgColumns[i];
165
- if (reqColumns.indexOf('!' + cfgColumn) < 0) {
166
- result.push(cfgColumn);
167
- }
168
- }
169
- return new SqlSegArg_1.SqlSegArg((0, convertColumnName_1.toSqlColumnNamesJoin)(result, sqlCfgModel));
170
- }
171
- // req 不为空:2. 取交集
172
- const result = [];
173
- for (let i = 0; i < reqColumns.length; i++) {
174
- const reqColumn = reqColumns[i];
175
- if (cfgColumns.indexOf(reqColumn) >= 0) {
176
- result.push(reqColumn);
177
- }
178
- }
179
- return new SqlSegArg_1.SqlSegArg((0, convertColumnName_1.toSqlColumnNamesJoin)(result, sqlCfgModel));
180
- }
181
- /**
182
- * 生成查询条件
183
- * @param req
184
- * @param sqlCfg
185
- * @param conditionName
186
- * @private
187
- */
188
- generateCondition(req, sqlCfg, conditionName) {
189
- if (MixinUtils_1.MixinUtils.isEmpty(conditionName)) {
190
- conditionName = 'condition';
191
- }
192
- const condition = req.getCondOrDataJsonObject(conditionName);
193
- const ss = new CrudProGenSqlCondition_1.CrudProGenSqlCondition(sqlCfg);
194
- return ss.generateCondition(condition);
195
- }
196
- generateOffsetLimit(requestCfg, sqlCfg, req) {
197
- const maxLimit = ModelUtils_1.ModelUtils.getMaxLimit(sqlCfg, requestCfg);
198
- const reqLimit = req.limit;
199
- const limit = Math.min(maxLimit, reqLimit);
200
- if (sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
201
- return new SqlSegArg_1.SqlSegArg(' LIMIT ? OFFSET ? ', [limit, req.offset]);
202
- }
203
- if (sqlCfg.sqlDbType === keys_1.SqlDbType.sqlserver) {
204
- return new SqlSegArg_1.SqlSegArg(' OFFSET ? ROWS FETCH NEXT ? ROWS ONLY ', [req.offset, limit]);
205
- }
206
- return new SqlSegArg_1.SqlSegArg(' limit ?,? ', [req.offset, limit]);
207
- }
208
- // 生成排序条件
209
- generateOrderBys(req, sqlCfgModel) {
210
- const orderBys = req.orderBys;
211
- if (MixinUtils_1.MixinUtils.isEmpty(orderBys)) {
212
- return null;
213
- }
214
- const orderByArr = orderBys.map(orderBy => {
215
- return (0, convertColumnName_1.toSqlColumnName)(orderBy.fieldName, sqlCfgModel) + ' ' + orderBy.orderType;
216
- });
217
- const sql = 'order by ' + orderByArr.join(',');
218
- return new SqlSegArg_1.SqlSegArg(sql);
219
- }
220
- generatePickResAs(req, world) {
221
- return new SqlSegArg_1.SqlSegArg(' ? ', [
222
- {
223
- ___GENERATE_GET_RES_ATTR___: world,
224
- },
225
- ]);
226
- }
227
- generateGetAttr(req, word) {
228
- const attrName = MixinUtils_1.MixinUtils.removeStringPrefix(word, '@@');
229
- if (MixinUtils_1.MixinUtils.isEmpty(attrName)) {
230
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_GET_ATTR_NAME_EMPTY, word);
231
- }
232
- const dataValue = req.getJsonObjectValue(attrName);
233
- if (typeof dataValue === 'undefined' || !TypeUtils_1.TypeUtils.isBasicType(dataValue)) {
234
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_GET_ATTR_VALUE_ERROR, word);
235
- }
236
- return new SqlSegArg_1.SqlSegArg(' ? ', [dataValue]);
237
- }
238
- generateDataUpdate(req, sqlCfgModel, dataName) {
239
- const data = req.getCondOrDataJsonObject(dataName);
240
- if (MixinUtils_1.MixinUtils.isEmpty(data)) {
241
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.DATA_GET_DATA_EMPTY_ON_UPDATE, dataName);
242
- }
243
- const keys = Object.keys(data).sort();
244
- const sqlList = [];
245
- const argList = [];
246
- for (let i = 0; i < keys.length; i++) {
247
- const key = keys[i];
248
- const arg = data[key];
249
- if (SqlFuncUtils_1.sqlFuncUtils.isSqlFuncArg(arg)) {
250
- const funcSQL = SqlFuncUtils_1.sqlFuncUtils.toFuncSQL(arg);
251
- sqlList.push((0, convertColumnName_1.toSqlColumnName)(key, sqlCfgModel) + '= ' + funcSQL);
252
- }
253
- else {
254
- sqlList.push((0, convertColumnName_1.toSqlColumnName)(key, sqlCfgModel) + '= ?');
255
- argList.push(arg);
256
- }
257
- }
258
- const sql = sqlList.join(',');
259
- return new SqlSegArg_1.SqlSegArg(sql, argList);
260
- }
261
- generateDataAsInsertValues(req, dataName) {
262
- const data = req.getCondOrDataJsonObject(dataName);
263
- if (MixinUtils_1.MixinUtils.isEmpty(data)) {
264
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_VALUES, dataName);
265
- }
266
- const keys = Object.keys(data).sort();
267
- const sqlList = [];
268
- const argList = [];
269
- for (let i = 0; i < keys.length; i++) {
270
- const key = keys[i];
271
- const arg = data[key];
272
- // 如 data: {xxxTime: {$byFunc:"NOW()"}}
273
- if (SqlFuncUtils_1.sqlFuncUtils.isSqlFuncArg(arg)) {
274
- const funcSQL = SqlFuncUtils_1.sqlFuncUtils.toFuncSQL(arg); // values( ? , ? , NOW() , ?)
275
- sqlList.push(funcSQL);
276
- }
277
- else {
278
- sqlList.push('?');
279
- argList.push(arg);
280
- }
281
- }
282
- const sql = sqlList.join(','); // "?,?,?,?"
283
- return new SqlSegArg_1.SqlSegArg(sql, argList);
284
- }
285
- generateSqlJavaFunction(requestCfg, tmpFuncName) {
286
- const exeCtx = this.getExecuteContext();
287
- const functionCfg = requestCfg.functionCfg;
288
- if (MixinUtils_1.MixinUtils.isEmpty(functionCfg)) {
289
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_SQL_FUNCTION_EMPTY, tmpFuncName);
290
- }
291
- const tmpFunCfg = functionCfg[tmpFuncName];
292
- if (ModelUtils_1.ModelUtils.checkFuncCfgValid(tmpFunCfg)) {
293
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_VALIDATE_CUSTOM_FUNCTION_EMPTY, tmpFuncName);
294
- }
295
- const exeFunCtx = new FuncContext_1.FuncContext();
296
- exeFunCtx.currentValue = null;
297
- exeFunCtx.reqModel = exeCtx.getReqModel();
298
- exeFunCtx.resModel = exeCtx.getResModel();
299
- const dataValue = this.serviceHub.executeFuncCfg(tmpFunCfg, exeFunCtx);
300
- return new SqlSegArg_1.SqlSegArg(' ? ', [dataValue]);
301
- }
302
- /**
303
- * 不会返回空。
304
- * @param sqlCfgModel
305
- * @private
306
- */
307
- async generateCfgColumns(sqlCfgModel) {
308
- const tableMeta = await this.serviceHub.getTableMeta(sqlCfgModel);
309
- const tableColumns = tableMeta.tableColumns;
310
- const cfgColumns = sqlCfgModel.columns || [];
311
- // 没有配置: 全量
312
- if (MixinUtils_1.MixinUtils.isEmpty(cfgColumns)) {
313
- return tableColumns;
314
- }
315
- // 黑名单:排除法
316
- if (isAnyStartWithExclude(cfgColumns)) {
317
- const excludeColumns = cfgColumns.filter(c => {
318
- return c.startsWith('!');
319
- });
320
- const excludeColumnsSet = new Set(excludeColumns);
321
- const result = [];
322
- for (let i = 0; i < tableColumns.length; i++) {
323
- const tableColumn = tableColumns[i];
324
- if (!excludeColumnsSet.has('!' + tableColumn)) {
325
- result.push(tableColumn);
326
- }
327
- }
328
- return result;
329
- }
330
- // 白名单
331
- return cfgColumns;
332
- }
333
- }
334
- exports.CrudProOriginToExecuteSql = CrudProOriginToExecuteSql;
@@ -1,24 +0,0 @@
1
- import { ICurdProServiceHub } from '../models/ServiceHub';
2
- import { ICrudProCfg, IExecuteUnsafeQueryCtx, ILogger, IPoolConnectionClient } from '../interfaces';
3
- import { SqlCfgModel } from '../models/SqlCfgModel';
4
- import { ExecuteContext } from '../models/ExecuteContext';
5
- import { IExecuteContextFunc } from '../models/ExecuteContextFunc';
6
- declare class CrudProServiceBase {
7
- protected serviceHub: ICurdProServiceHub;
8
- constructor(serviceHub: ICurdProServiceHub);
9
- protected getExecuteContext(): ExecuteContext;
10
- protected getContextFunc(): IExecuteContextFunc;
11
- protected get logger(): ILogger;
12
- protected getTxConnectionBySqlCfg(sqlCfgModel: SqlCfgModel): Promise<IPoolConnectionClient>;
13
- /**
14
- * 不做任何检验,直接执行SQL,只能CrudPro内部使用,不对外使用
15
- * @param obj
16
- * @param sql
17
- * @param values
18
- * @protected
19
- */
20
- protected executeUnsafeQuery(obj: IExecuteUnsafeQueryCtx, sql: string, values?: any): Promise<any[]>;
21
- protected getContextCfg(): ICrudProCfg;
22
- protected getExecuteFunction(funcName: string): any;
23
- }
24
- export { CrudProServiceBase };
@@ -1,79 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CrudProServiceBase = void 0;
4
- const _ = require("lodash");
5
- const MixinUtils_1 = require("../utils/MixinUtils");
6
- const TypeUtils_1 = require("../utils/TypeUtils");
7
- const CompareUtils_1 = require("../utils/CompareUtils");
8
- const DateTimeUtils_1 = require("../utils/DateTimeUtils");
9
- const defaultConfigs_1 = require("../defaultConfigs");
10
- function createBuildInExecuteFuncMap() {
11
- return {
12
- ...DateTimeUtils_1.DateTimeUtils,
13
- ...CompareUtils_1.CompareUtils,
14
- ...MixinUtils_1.MixinUtils,
15
- ...TypeUtils_1.TypeUtils,
16
- };
17
- }
18
- const buildInExecuteFuncMap = createBuildInExecuteFuncMap();
19
- class CrudProServiceBase {
20
- constructor(serviceHub) {
21
- this.serviceHub = serviceHub;
22
- }
23
- getExecuteContext() {
24
- return this.serviceHub.getExecuteContext();
25
- }
26
- getContextFunc() {
27
- return this.getExecuteContext().contextFunc;
28
- }
29
- get logger() {
30
- return this.getExecuteContext().getLogger();
31
- }
32
- async getTxConnectionBySqlCfg(sqlCfgModel) {
33
- const executeContext = this.getExecuteContext();
34
- const transaction = executeContext.getTransaction();
35
- const contextFunc = this.getContextFunc();
36
- const pool = await contextFunc.getConnectionPool(sqlCfgModel);
37
- return transaction.getTxConnection(pool);
38
- }
39
- /**
40
- * 不做任何检验,直接执行SQL,只能CrudPro内部使用,不对外使用
41
- * @param obj
42
- * @param sql
43
- * @param values
44
- * @protected
45
- */
46
- async executeUnsafeQuery(obj, sql, values) {
47
- const sqlCfgModel = {
48
- sqlTable: obj.sqlTable,
49
- sqlDatabase: obj.sqlDatabase,
50
- sqlDbType: obj.sqlDbType,
51
- columns: [],
52
- columnsRelation: [],
53
- maxLimit: defaultConfigs_1.DEFAULT_MAX_LIMIT,
54
- resName: 'executeUnsafeQuery',
55
- originSql: sql,
56
- executeSql: sql,
57
- executeSqlArgs: values,
58
- crudType: null,
59
- };
60
- const connection = await this.getTxConnectionBySqlCfg(sqlCfgModel);
61
- return await connection.query(sql, values);
62
- }
63
- getContextCfg() {
64
- return this.getExecuteContext().getContextCfg();
65
- }
66
- getExecuteFunction(funcName) {
67
- const contextFunc = this.getContextFunc();
68
- const functionMap = contextFunc.getFunctionMap();
69
- if (functionMap) {
70
- const func = _.get(functionMap, funcName);
71
- if (typeof func === 'function') {
72
- return func;
73
- }
74
- }
75
- console.log('buildInExecuteFuncMap', Object.keys(buildInExecuteFuncMap));
76
- return _.get(buildInExecuteFuncMap, funcName);
77
- }
78
- }
79
- exports.CrudProServiceBase = CrudProServiceBase;
@@ -1,9 +0,0 @@
1
- import { CrudProServiceBase } from './CrudProServiceBase';
2
- import { SqlCfgModel } from '../models/SqlCfgModel';
3
- import { ITableMeta } from '../interfaces';
4
- declare class CrudProTableMetaService extends CrudProServiceBase {
5
- getTableMeta(sqlCfgModel: SqlCfgModel): Promise<ITableMeta>;
6
- private loadTableMeta;
7
- private loadTableColumnInfo;
8
- }
9
- export { CrudProTableMetaService };
@@ -1,78 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CrudProTableMetaService = void 0;
4
- const CrudProServiceBase_1 = require("./CrudProServiceBase");
5
- const keys_1 = require("../models/keys");
6
- const convertMix_1 = require("../utils/sqlConvert/convertMix");
7
- class CrudProTableMetaCache {
8
- constructor() {
9
- this.cacheMap = {};
10
- }
11
- getCacheKey(sqlCfgModel) {
12
- return `${sqlCfgModel.sqlDatabase}:::${sqlCfgModel.sqlSchema}:::${sqlCfgModel.sqlTable}`;
13
- }
14
- getMeta(sqlCfgModel) {
15
- const cacheKey = this.getCacheKey(sqlCfgModel);
16
- const obj = this.cacheMap[cacheKey];
17
- if (obj && obj.expiredTime < Date.now()) {
18
- return obj;
19
- }
20
- return null;
21
- }
22
- setMeta(sqlCfgModel, metaObj) {
23
- const cacheKey = this.getCacheKey(sqlCfgModel);
24
- this.cacheMap[cacheKey] = metaObj;
25
- }
26
- }
27
- const metaCache = new CrudProTableMetaCache();
28
- class CrudProTableMetaService extends CrudProServiceBase_1.CrudProServiceBase {
29
- async getTableMeta(sqlCfgModel) {
30
- let obj = metaCache.getMeta(sqlCfgModel);
31
- if (!obj) {
32
- obj = await this.loadTableMeta(sqlCfgModel);
33
- metaCache.setMeta(sqlCfgModel, obj);
34
- }
35
- return obj;
36
- }
37
- async loadTableMeta(sqlCfgModel) {
38
- const { tableMetaCacheTime } = this.getContextCfg();
39
- const obj = {
40
- expiredTime: Date.now() + tableMetaCacheTime || 1000 * 3600 * 24 * 365,
41
- tableColumns: [],
42
- };
43
- const baseInfo = {
44
- sqlTable: sqlCfgModel.sqlTable,
45
- sqlDatabase: sqlCfgModel.sqlDatabase,
46
- sqlDbType: sqlCfgModel.sqlDbType,
47
- };
48
- obj.tableColumns = await this.loadTableColumnInfo(baseInfo);
49
- return obj;
50
- }
51
- async loadTableColumnInfo(baseInfo) {
52
- if (baseInfo.sqlDbType === keys_1.SqlDbType.mysql) {
53
- const queryRes = await this.executeUnsafeQuery(baseInfo, 'describe ' + baseInfo.sqlTable);
54
- const tableDescribe = (0, convertMix_1.pickAndConvertRowsByMix)(queryRes, baseInfo.sqlDbType);
55
- const tableDescribe2 = JSON.parse(JSON.stringify(tableDescribe));
56
- return tableDescribe2.map(fieldObj => {
57
- return fieldObj['Field'];
58
- });
59
- }
60
- else if (baseInfo.sqlDbType === keys_1.SqlDbType.postgres) {
61
- const schemaname = 'public';
62
- const columnArraySql = `
63
- SELECT
64
- *
65
- FROM information_schema.columns
66
- WHERE table_schema = '${schemaname}' and table_name = '${baseInfo.sqlTable}'
67
- ORDER BY ordinal_position;
68
- `.trim();
69
- const queryRes = await this.executeUnsafeQuery(baseInfo, columnArraySql);
70
- const tableDescribe = (0, convertMix_1.pickAndConvertRowsByMix)(queryRes, baseInfo.sqlDbType);
71
- return tableDescribe.map(fieldObj => {
72
- return fieldObj['column_name'];
73
- });
74
- }
75
- throw new Error('暂不支持的数据库类型:' + baseInfo.sqlDbType);
76
- }
77
- }
78
- exports.CrudProTableMetaService = CrudProTableMetaService;
@@ -1,32 +0,0 @@
1
- import { IFuncCfgModel, IRequestCfgModel, ITableMeta } from '../interfaces';
2
- import { RequestModel } from '../models/RequestModel';
3
- import { ExecuteContext } from '../models/ExecuteContext';
4
- import { SqlCfgModel } from '../models/SqlCfgModel';
5
- import { RequestCfgModel } from '../models/RequestCfgModel';
6
- import { ICurdProServiceHub } from '../models/ServiceHub';
7
- import { FuncContext } from '../models/FuncContext';
8
- declare class CurdProServiceHub implements ICurdProServiceHub {
9
- private readonly executeContext;
10
- private readonly fieldValidateService;
11
- private readonly fieldUpdateService;
12
- private readonly cachedCfgService;
13
- private readonly executeSqlService;
14
- private readonly genSqlService;
15
- private readonly originToExecuteSql;
16
- private readonly executeFuncService;
17
- private readonly tableMetaService;
18
- constructor(executeContext: ExecuteContext);
19
- getExecuteContext(): ExecuteContext;
20
- validateByAllow(cfgModel: RequestCfgModel, reqModel: RequestModel): void;
21
- validateByReject(cfgModel: RequestCfgModel, reqModel: RequestModel): void;
22
- validateByCfg(cfgModel: RequestCfgModel, reqModel: RequestModel): void;
23
- validateByAuthCfg(cfgModel: RequestCfgModel, reqModel: RequestModel): Promise<any>;
24
- updateByCfg(cfgModel: RequestCfgModel, reqModel: RequestModel): void;
25
- getCachedCfgByMethod(method: string, isEnableCache: boolean): Promise<IRequestCfgModel>;
26
- generateSQLList(): Promise<void>;
27
- executeSqlCfgModels(): Promise<void>;
28
- convertOriginToExecuteSql(sqlCfgModel: SqlCfgModel): Promise<void>;
29
- executeFuncCfg(funCfg: IFuncCfgModel, funcContext: FuncContext): any;
30
- getTableMeta(sqlCfgModel: SqlCfgModel): Promise<ITableMeta>;
31
- }
32
- export { CurdProServiceHub };
@@ -1,64 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CurdProServiceHub = void 0;
4
- const CrudProFieldValidateService_1 = require("./CrudProFieldValidateService");
5
- const CrudProFieldUpdateService_1 = require("./CrudProFieldUpdateService");
6
- const CrudProCachedCfgService_1 = require("./CrudProCachedCfgService");
7
- const CrudProExecuteSqlService_1 = require("./CrudProExecuteSqlService");
8
- const CrudProGenSqlService_1 = require("./CrudProGenSqlService");
9
- const CrudProOriginToExecuteSql_1 = require("./CrudProOriginToExecuteSql");
10
- const CrudProExecuteFuncService_1 = require("./CrudProExecuteFuncService");
11
- const CrudProTableMetaService_1 = require("./CrudProTableMetaService");
12
- class CurdProServiceHub {
13
- constructor(executeContext) {
14
- this.executeContext = executeContext;
15
- this.fieldValidateService = new CrudProFieldValidateService_1.CrudProFieldValidateService(this);
16
- this.fieldUpdateService = new CrudProFieldUpdateService_1.CrudProFieldUpdateService(this);
17
- this.cachedCfgService = new CrudProCachedCfgService_1.CrudProCachedCfgService(this);
18
- this.executeSqlService = new CrudProExecuteSqlService_1.CrudProExecuteSqlService(this);
19
- this.genSqlService = new CrudProGenSqlService_1.CrudProGenSqlService(this);
20
- this.originToExecuteSql = new CrudProOriginToExecuteSql_1.CrudProOriginToExecuteSql(this);
21
- this.executeFuncService = new CrudProExecuteFuncService_1.CrudProExecuteFuncService(this);
22
- this.tableMetaService = new CrudProTableMetaService_1.CrudProTableMetaService(this);
23
- }
24
- getExecuteContext() {
25
- return this.executeContext;
26
- }
27
- validateByAllow(cfgModel, reqModel) {
28
- return this.fieldValidateService.validateByAllow(cfgModel, reqModel);
29
- }
30
- validateByReject(cfgModel, reqModel) {
31
- return this.fieldValidateService.validateByReject(cfgModel, reqModel);
32
- }
33
- validateByCfg(cfgModel, reqModel) {
34
- return this.fieldValidateService.validateByCfg(cfgModel, reqModel);
35
- }
36
- async validateByAuthCfg(cfgModel, reqModel) {
37
- const contextFunc = this.executeContext.contextFunc;
38
- if (contextFunc && contextFunc.validateByAuthCfg) {
39
- return contextFunc.validateByAuthCfg(cfgModel, reqModel);
40
- }
41
- }
42
- updateByCfg(cfgModel, reqModel) {
43
- return this.fieldUpdateService.updateByCfg(cfgModel, reqModel);
44
- }
45
- async getCachedCfgByMethod(method, isEnableCache) {
46
- return this.cachedCfgService.getCachedCfgByMethod(method, isEnableCache);
47
- }
48
- async generateSQLList() {
49
- return this.genSqlService.generateSQLList();
50
- }
51
- async executeSqlCfgModels() {
52
- return this.executeSqlService.executeSqlCfgModels();
53
- }
54
- async convertOriginToExecuteSql(sqlCfgModel) {
55
- return this.originToExecuteSql.convertOriginToExecuteSql(sqlCfgModel);
56
- }
57
- executeFuncCfg(funCfg, funcContext) {
58
- return this.executeFuncService.executeFuncCfg(funCfg, funcContext);
59
- }
60
- async getTableMeta(sqlCfgModel) {
61
- return await this.tableMetaService.getTableMeta(sqlCfgModel);
62
- }
63
- }
64
- exports.CurdProServiceHub = CurdProServiceHub;