midway-fatcms 0.0.1-beta.22 → 0.0.1-beta.24

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 (420) hide show
  1. package/.eslintrc.json +14 -12
  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 +187 -185
  6. package/dist/config/seed/aeskey.txt +1 -1
  7. package/dist/config/utils.d.ts +1 -1
  8. package/dist/config/utils.js +23 -23
  9. package/dist/configuration.d.ts +7 -7
  10. package/dist/configuration.js +113 -114
  11. package/dist/controller/base/BaseApiController.d.ts +37 -31
  12. package/dist/controller/base/BaseApiController.js +164 -146
  13. package/dist/controller/gateway/AnyApiGatewayController.d.ts +13 -13
  14. package/dist/controller/gateway/AnyApiGatewayController.js +55 -55
  15. package/dist/controller/gateway/AsyncTaskController.d.ts +20 -14
  16. package/dist/controller/gateway/AsyncTaskController.js +181 -108
  17. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
  18. package/dist/controller/gateway/CrudMtdGatewayController.js +119 -119
  19. package/dist/controller/gateway/CrudStdGatewayController.d.ts +38 -38
  20. package/dist/controller/gateway/CrudStdGatewayController.js +137 -137
  21. package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
  22. package/dist/controller/gateway/DocGatewayController.js +179 -179
  23. package/dist/controller/gateway/FileController.d.ts +25 -25
  24. package/dist/controller/gateway/FileController.js +129 -129
  25. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
  26. package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
  27. package/dist/controller/gateway/PublicApiController.d.ts +27 -27
  28. package/dist/controller/gateway/PublicApiController.js +165 -165
  29. package/dist/controller/gateway/StaticController.d.ts +24 -23
  30. package/dist/controller/gateway/StaticController.js +288 -284
  31. package/dist/controller/helpers.controller.d.ts +39 -39
  32. package/dist/controller/helpers.controller.js +188 -188
  33. package/dist/controller/home.controller.d.ts +9 -9
  34. package/dist/controller/home.controller.js +71 -71
  35. package/dist/controller/manage/AnyApiMangeApi.d.ts +10 -10
  36. package/dist/controller/manage/AnyApiMangeApi.js +98 -98
  37. package/dist/controller/manage/AppLogMangeApi.d.ts +10 -10
  38. package/dist/controller/manage/AppLogMangeApi.js +88 -88
  39. package/dist/controller/manage/AppMangeApi.d.ts +10 -10
  40. package/dist/controller/manage/AppMangeApi.js +88 -88
  41. package/dist/controller/manage/AppPageMangeApi.d.ts +10 -10
  42. package/dist/controller/manage/AppPageMangeApi.js +87 -87
  43. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +10 -10
  44. package/dist/controller/manage/AppSchemaHistoryApi.js +83 -83
  45. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +10 -10
  46. package/dist/controller/manage/CrudMethodsMangeApi.js +84 -84
  47. package/dist/controller/manage/CrudStandardDesignApi.d.ts +38 -38
  48. package/dist/controller/manage/CrudStandardDesignApi.js +334 -334
  49. package/dist/controller/manage/DataDictManageApi.d.ts +15 -15
  50. package/dist/controller/manage/DataDictManageApi.js +133 -133
  51. package/dist/controller/manage/DeployManageApi.d.ts +19 -19
  52. package/dist/controller/manage/DeployManageApi.js +180 -180
  53. package/dist/controller/manage/DocLibManageApi.d.ts +10 -10
  54. package/dist/controller/manage/DocLibManageApi.js +104 -104
  55. package/dist/controller/manage/DocManageApi.d.ts +11 -11
  56. package/dist/controller/manage/DocManageApi.js +130 -130
  57. package/dist/controller/manage/FileManageApi.d.ts +13 -13
  58. package/dist/controller/manage/FileManageApi.js +77 -77
  59. package/dist/controller/manage/LowCodeTplManageApi.d.ts +13 -13
  60. package/dist/controller/manage/LowCodeTplManageApi.js +86 -86
  61. package/dist/controller/manage/MenuManageApi.d.ts +10 -10
  62. package/dist/controller/manage/MenuManageApi.js +93 -93
  63. package/dist/controller/manage/ProxyApiMangeApi.d.ts +10 -10
  64. package/dist/controller/manage/ProxyApiMangeApi.js +87 -87
  65. package/dist/controller/manage/SuperAdminManageApi.d.ts +24 -24
  66. package/dist/controller/manage/SuperAdminManageApi.js +153 -153
  67. package/dist/controller/manage/SysConfigMangeApi.d.ts +11 -11
  68. package/dist/controller/manage/SysConfigMangeApi.js +126 -126
  69. package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
  70. package/dist/controller/manage/SystemInfoManageApi.js +72 -72
  71. package/dist/controller/manage/UserAccountManageApi.d.ts +14 -14
  72. package/dist/controller/manage/UserAccountManageApi.js +129 -129
  73. package/dist/controller/manage/WorkbenchMangeApi.d.ts +11 -11
  74. package/dist/controller/manage/WorkbenchMangeApi.js +103 -103
  75. package/dist/controller/myinfo/AuthController.d.ts +33 -33
  76. package/dist/controller/myinfo/AuthController.js +136 -136
  77. package/dist/controller/myinfo/MyInfoController.d.ts +13 -13
  78. package/dist/controller/myinfo/MyInfoController.js +51 -51
  79. package/dist/controller/render/AppRenderController.d.ts +11 -11
  80. package/dist/controller/render/AppRenderController.js +91 -91
  81. package/dist/controller/test.controller.d.ts +8 -8
  82. package/dist/controller/test.controller.js +51 -51
  83. package/dist/filter/default.filter.d.ts +7 -7
  84. package/dist/filter/default.filter.js +23 -23
  85. package/dist/filter/notfound.filter.d.ts +5 -5
  86. package/dist/filter/notfound.filter.js +20 -20
  87. package/dist/index.d.ts +102 -101
  88. package/dist/index.js +120 -119
  89. package/dist/interface.d.ts +27 -27
  90. package/dist/interface.js +3 -3
  91. package/dist/libs/crud-pro/CrudPro.d.ts +37 -37
  92. package/dist/libs/crud-pro/CrudPro.js +136 -136
  93. package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
  94. package/dist/libs/crud-pro/defaultConfigs.js +15 -15
  95. package/dist/libs/crud-pro/exceptions.d.ts +104 -104
  96. package/dist/libs/crud-pro/exceptions.js +117 -117
  97. package/dist/libs/crud-pro/interfaces.d.ts +163 -163
  98. package/dist/libs/crud-pro/interfaces.js +12 -12
  99. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +49 -43
  100. package/dist/libs/crud-pro/models/ExecuteContext.js +79 -79
  101. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -38
  102. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -72
  103. package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
  104. package/dist/libs/crud-pro/models/FuncContext.js +6 -6
  105. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
  106. package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
  107. package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
  108. package/dist/libs/crud-pro/models/RequestModel.js +113 -113
  109. package/dist/libs/crud-pro/models/ResModel.d.ts +16 -16
  110. package/dist/libs/crud-pro/models/ResModel.js +2 -2
  111. package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
  112. package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
  113. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +22 -22
  114. package/dist/libs/crud-pro/models/SqlCfgModel.js +40 -40
  115. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +6 -6
  116. package/dist/libs/crud-pro/models/SqlSegArg.js +12 -12
  117. package/dist/libs/crud-pro/models/Transaction.d.ts +29 -29
  118. package/dist/libs/crud-pro/models/Transaction.js +67 -67
  119. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +28 -28
  120. package/dist/libs/crud-pro/models/TransactionMySQL.js +76 -76
  121. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +28 -28
  122. package/dist/libs/crud-pro/models/TransactionPostgres.js +85 -85
  123. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +34 -34
  124. package/dist/libs/crud-pro/models/TransactionSqlServer.js +92 -92
  125. package/dist/libs/crud-pro/models/keys.d.ts +106 -106
  126. package/dist/libs/crud-pro/models/keys.js +149 -149
  127. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -11
  128. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -73
  129. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
  130. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +112 -112
  131. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
  132. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +225 -223
  133. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +9 -9
  134. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +51 -51
  135. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +13 -13
  136. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +148 -148
  137. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +24 -24
  138. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +340 -340
  139. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
  140. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -165
  141. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
  142. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +334 -334
  143. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -24
  144. package/dist/libs/crud-pro/services/CrudProServiceBase.js +79 -79
  145. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -9
  146. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +78 -78
  147. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +32 -32
  148. package/dist/libs/crud-pro/services/CurdProServiceHub.js +64 -64
  149. package/dist/libs/crud-pro/sql.txt +120 -120
  150. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +9 -9
  151. package/dist/libs/crud-pro/utils/CompareUtils.js +25 -25
  152. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +9 -9
  153. package/dist/libs/crud-pro/utils/DatabaseName.js +50 -50
  154. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +7 -7
  155. package/dist/libs/crud-pro/utils/DateTimeUtils.js +21 -21
  156. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +19 -19
  157. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +47 -47
  158. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +5 -5
  159. package/dist/libs/crud-pro/utils/MessageParseUtils.js +33 -33
  160. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +39 -39
  161. package/dist/libs/crud-pro/utils/MixinUtils.js +255 -255
  162. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +11 -11
  163. package/dist/libs/crud-pro/utils/ModelUtils.js +49 -49
  164. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +11 -11
  165. package/dist/libs/crud-pro/utils/MultiKeyMap.js +63 -63
  166. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +5 -5
  167. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +29 -29
  168. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +40 -40
  169. package/dist/libs/crud-pro/utils/TypeUtils.js +166 -166
  170. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +3 -3
  171. package/dist/libs/crud-pro/utils/ValidateUtils.js +165 -165
  172. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +3 -3
  173. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +19 -19
  174. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +3 -3
  175. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +20 -20
  176. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +3 -3
  177. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +20 -20
  178. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +4 -4
  179. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +21 -21
  180. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -3
  181. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -22
  182. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +2 -2
  183. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +11 -11
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +11 -11
  186. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +2 -2
  187. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +128 -128
  188. package/dist/libs/global-config/global-config.d.ts +45 -45
  189. package/dist/libs/global-config/global-config.js +33 -33
  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 -4
  199. package/dist/libs/utils/functions.js +68 -63
  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 +5 -5
  205. package/dist/libs/utils/parseCreateSql.js +86 -86
  206. package/dist/libs/utils/render-utils.d.ts +28 -28
  207. package/dist/libs/utils/render-utils.js +135 -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 +253 -253
  212. package/dist/middleware/permission.middleware.d.ts +18 -18
  213. package/dist/middleware/permission.middleware.js +74 -74
  214. package/dist/middleware/tx.middleware.d.ts +9 -9
  215. package/dist/middleware/tx.middleware.js +40 -40
  216. package/dist/models/AsyncTaskModel.d.ts +72 -69
  217. package/dist/models/AsyncTaskModel.js +29 -26
  218. package/dist/models/RedisKeys.d.ts +11 -8
  219. package/dist/models/RedisKeys.js +14 -11
  220. package/dist/models/SystemEntities.d.ts +98 -98
  221. package/dist/models/SystemEntities.js +2 -2
  222. package/dist/models/SystemPerm.d.ts +95 -95
  223. package/dist/models/SystemPerm.js +100 -100
  224. package/dist/models/SystemTables.d.ts +25 -25
  225. package/dist/models/SystemTables.js +28 -28
  226. package/dist/models/bizmodels.d.ts +96 -69
  227. package/dist/models/bizmodels.js +39 -34
  228. package/dist/models/contextLogger.d.ts +25 -25
  229. package/dist/models/contextLogger.js +112 -112
  230. package/dist/models/devops.d.ts +12 -12
  231. package/dist/models/devops.js +19 -19
  232. package/dist/models/userSession.d.ts +61 -61
  233. package/dist/models/userSession.js +165 -165
  234. package/dist/schedule/anonymousContext.d.ts +14 -13
  235. package/dist/schedule/anonymousContext.js +59 -59
  236. package/dist/schedule/index.d.ts +4 -4
  237. package/dist/schedule/index.js +10 -10
  238. package/dist/schedule/runSchedule.d.ts +12 -15
  239. package/dist/schedule/runSchedule.js +68 -68
  240. package/dist/schedule/scheduleNames.d.ts +13 -13
  241. package/dist/schedule/scheduleNames.js +17 -17
  242. package/dist/service/AuthService.d.ts +70 -70
  243. package/dist/service/AuthService.js +251 -251
  244. package/dist/service/EnumInfoService.d.ts +30 -30
  245. package/dist/service/EnumInfoService.js +126 -126
  246. package/dist/service/FileCenterService.d.ts +43 -43
  247. package/dist/service/FileCenterService.js +351 -351
  248. package/dist/service/SysConfigService.d.ts +7 -7
  249. package/dist/service/SysConfigService.js +47 -47
  250. package/dist/service/UserAccountService.d.ts +23 -23
  251. package/dist/service/UserAccountService.js +107 -107
  252. package/dist/service/UserSessionService.d.ts +16 -16
  253. package/dist/service/UserSessionService.js +86 -86
  254. package/dist/service/VisitStatService.d.ts +14 -14
  255. package/dist/service/VisitStatService.js +158 -158
  256. package/dist/service/WorkbenchService.d.ts +20 -20
  257. package/dist/service/WorkbenchService.js +159 -155
  258. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  259. package/dist/service/anyapi/AnyApiSandboxService.js +122 -122
  260. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  261. package/dist/service/anyapi/AnyApiService.js +181 -181
  262. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +37 -37
  263. package/dist/service/asyncTask/AsyncTaskRunnerService.js +242 -232
  264. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -7
  265. package/dist/service/asyncTask/AsyncTaskService.js +34 -34
  266. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
  267. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
  268. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
  269. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +197 -0
  270. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
  271. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +130 -0
  272. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
  273. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +121 -0
  274. package/dist/service/base/ApiBaseService.d.ts +15 -15
  275. package/dist/service/base/ApiBaseService.js +50 -50
  276. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  277. package/dist/service/base/ApiRateLimiter.js +51 -51
  278. package/dist/service/base/BaseService.d.ts +41 -29
  279. package/dist/service/base/BaseService.js +101 -79
  280. package/dist/service/base/RedisCacheService.d.ts +13 -13
  281. package/dist/service/base/RedisCacheService.js +50 -50
  282. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  283. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  284. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  285. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  286. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  287. package/dist/service/crudstd/CrudStdRelationService.js +85 -85
  288. package/dist/service/crudstd/CrudStdService.d.ts +63 -51
  289. package/dist/service/crudstd/CrudStdService.js +259 -227
  290. package/dist/service/curd/CrudProQuick.d.ts +24 -24
  291. package/dist/service/curd/CrudProQuick.js +109 -105
  292. package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
  293. package/dist/service/curd/CurdMixByAccountService.js +93 -93
  294. package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
  295. package/dist/service/curd/CurdMixByDictService.js +114 -113
  296. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -31
  297. package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -202
  298. package/dist/service/curd/CurdMixBySysConfigService.d.ts +9 -9
  299. package/dist/service/curd/CurdMixBySysConfigService.js +80 -80
  300. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +10 -10
  301. package/dist/service/curd/CurdMixByWorkbenchService.js +78 -78
  302. package/dist/service/curd/CurdMixService.d.ts +27 -17
  303. package/dist/service/curd/CurdMixService.js +100 -76
  304. package/dist/service/curd/CurdMixUtils.d.ts +51 -35
  305. package/dist/service/curd/CurdMixUtils.js +275 -238
  306. package/dist/service/curd/CurdProService.d.ts +32 -31
  307. package/dist/service/curd/CurdProService.js +210 -207
  308. package/dist/service/curd/fixCfgModel.d.ts +3 -3
  309. package/dist/service/curd/fixCfgModel.js +107 -107
  310. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  311. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  312. package/dist/service/proxyapi/ProxyApiService.d.ts +60 -60
  313. package/dist/service/proxyapi/ProxyApiService.js +260 -260
  314. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  315. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  316. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  317. package/dist/service/proxyapi/RouteHandler.js +9 -9
  318. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  319. package/dist/service/proxyapi/RouteTrie.js +63 -63
  320. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  321. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  322. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  323. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  324. package/dist/views/404_app.html +31 -31
  325. package/dist/views/404_workbench.html +34 -34
  326. package/index.d.ts +10 -10
  327. package/package.json +80 -78
  328. package/src/config/config.default.ts +207 -203
  329. package/src/config/seed/aeskey.txt +1 -1
  330. package/src/config/utils.ts +2 -3
  331. package/src/configuration.ts +5 -12
  332. package/src/controller/base/BaseApiController.ts +21 -3
  333. package/src/controller/gateway/AsyncTaskController.ts +76 -2
  334. package/src/controller/gateway/StaticController.ts +15 -12
  335. package/src/controller/manage/AnyApiMangeApi.ts +66 -66
  336. package/src/controller/manage/AppLogMangeApi.ts +53 -53
  337. package/src/controller/manage/AppMangeApi.ts +53 -53
  338. package/src/controller/manage/AppPageMangeApi.ts +52 -52
  339. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -49
  340. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -49
  341. package/src/controller/manage/DataDictManageApi.ts +78 -78
  342. package/src/controller/manage/DocLibManageApi.ts +69 -69
  343. package/src/controller/manage/DocManageApi.ts +99 -99
  344. package/src/controller/manage/FileManageApi.ts +45 -45
  345. package/src/controller/manage/LowCodeTplManageApi.ts +52 -52
  346. package/src/controller/manage/MenuManageApi.ts +58 -58
  347. package/src/controller/manage/ProxyApiMangeApi.ts +52 -52
  348. package/src/controller/manage/SysConfigMangeApi.ts +95 -95
  349. package/src/controller/manage/UserAccountManageApi.ts +94 -94
  350. package/src/controller/manage/WorkbenchMangeApi.ts +72 -72
  351. package/src/index.ts +106 -105
  352. package/src/interface.ts +31 -31
  353. package/src/libs/crud-pro/models/ExecuteContext.ts +13 -4
  354. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +2 -3
  355. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +8 -9
  356. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -86
  357. package/src/libs/crud-pro/sql.txt +120 -120
  358. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +26 -26
  359. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +25 -25
  360. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +11 -11
  361. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +11 -11
  362. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +129 -129
  363. package/src/libs/utils/functions.ts +73 -67
  364. package/src/libs/utils/render-utils.ts +184 -184
  365. package/src/middleware/permission.middleware.ts +1 -2
  366. package/src/models/AsyncTaskModel.ts +82 -79
  367. package/src/models/RedisKeys.ts +10 -11
  368. package/src/models/SystemEntities.ts +115 -115
  369. package/src/models/SystemPerm.ts +105 -105
  370. package/src/models/SystemTables.ts +27 -27
  371. package/src/models/bizmodels.ts +120 -88
  372. package/src/models/contextLogger.ts +132 -132
  373. package/src/models/devops.ts +17 -17
  374. package/src/models/userSession.ts +216 -216
  375. package/src/schedule/anonymousContext.ts +17 -23
  376. package/src/schedule/index.ts +12 -12
  377. package/src/schedule/runSchedule.ts +82 -83
  378. package/src/schedule/scheduleNames.ts +21 -21
  379. package/src/service/AuthService.ts +275 -275
  380. package/src/service/EnumInfoService.ts +22 -27
  381. package/src/service/FileCenterService.ts +0 -5
  382. package/src/service/SysConfigService.ts +4 -5
  383. package/src/service/UserAccountService.ts +107 -110
  384. package/src/service/UserSessionService.ts +12 -16
  385. package/src/service/WorkbenchService.ts +15 -15
  386. package/src/service/anyapi/AnyApiSandboxService.ts +121 -121
  387. package/src/service/anyapi/AnyApiService.ts +187 -187
  388. package/src/service/asyncTask/AsyncTaskRunnerService.ts +19 -8
  389. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  390. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +224 -0
  391. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +147 -0
  392. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +138 -0
  393. package/src/service/base/ApiBaseService.ts +3 -3
  394. package/src/service/base/ApiRateLimiter.ts +59 -59
  395. package/src/service/base/BaseService.ts +100 -74
  396. package/src/service/base/RedisCacheService.ts +38 -38
  397. package/src/service/crudstd/CrudStdActionService.ts +27 -27
  398. package/src/service/crudstd/CrudStdConstant.ts +62 -62
  399. package/src/service/crudstd/CrudStdRelationService.ts +78 -78
  400. package/src/service/crudstd/CrudStdService.ts +283 -243
  401. package/src/service/curd/CrudProQuick.ts +11 -17
  402. package/src/service/curd/CurdMixByAccountService.ts +8 -9
  403. package/src/service/curd/CurdMixByDictService.ts +19 -24
  404. package/src/service/curd/CurdMixByLinkToCustomService.ts +10 -9
  405. package/src/service/curd/CurdMixBySysConfigService.ts +8 -13
  406. package/src/service/curd/CurdMixByWorkbenchService.ts +7 -8
  407. package/src/service/curd/CurdMixService.ts +37 -5
  408. package/src/service/curd/CurdMixUtils.ts +65 -45
  409. package/src/service/curd/CurdProService.ts +42 -48
  410. package/src/service/curd/fixCfgModel.ts +139 -139
  411. package/src/service/proxyapi/ProxyApiLoadService.ts +174 -174
  412. package/src/service/proxyapi/ProxyApiService.ts +262 -262
  413. package/src/service/proxyapi/ProxyApiUtils.ts +32 -32
  414. package/src/service/proxyapi/RouteHandler.ts +8 -8
  415. package/src/service/proxyapi/RouteTrie.ts +74 -74
  416. package/src/service/proxyapi/WeightedRandom.ts +37 -37
  417. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -44
  418. package/src/views/404_app.html +31 -31
  419. package/src/views/404_workbench.html +34 -34
  420. package/tsconfig.json +32 -32
@@ -1,334 +1,334 @@
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
+ "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;