midway-fatcms 0.0.2 → 0.0.3

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 (396) hide show
  1. package/.eslintrc.json +14 -14
  2. package/.prettierrc.js +4 -4
  3. package/README.md +406 -406
  4. package/dist/config/config.default.d.ts +3 -3
  5. package/dist/config/config.default.js +177 -177
  6. package/dist/config/utils.d.ts +1 -1
  7. package/dist/config/utils.js +23 -23
  8. package/dist/configuration.d.ts +7 -7
  9. package/dist/configuration.js +113 -113
  10. package/dist/controller/base/BaseApiController.d.ts +49 -49
  11. package/dist/controller/base/BaseApiController.js +198 -198
  12. package/dist/controller/gateway/AnyApiGatewayController.d.ts +13 -13
  13. package/dist/controller/gateway/AnyApiGatewayController.js +55 -55
  14. package/dist/controller/gateway/AsyncTaskController.d.ts +20 -20
  15. package/dist/controller/gateway/AsyncTaskController.js +181 -181
  16. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +21 -21
  17. package/dist/controller/gateway/CrudMtdGatewayController.js +122 -122
  18. package/dist/controller/gateway/CrudStdGatewayController.d.ts +39 -39
  19. package/dist/controller/gateway/CrudStdGatewayController.js +149 -149
  20. package/dist/controller/gateway/DocGatewayController.d.ts +27 -27
  21. package/dist/controller/gateway/DocGatewayController.js +181 -181
  22. package/dist/controller/gateway/FileController.d.ts +32 -32
  23. package/dist/controller/gateway/FileController.js +160 -160
  24. package/dist/controller/gateway/FlowInstanceController.d.ts +16 -16
  25. package/dist/controller/gateway/FlowInstanceController.js +48 -48
  26. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +18 -18
  27. package/dist/controller/gateway/ProxyApiGatewayController.js +78 -78
  28. package/dist/controller/gateway/PublicApiController.d.ts +33 -33
  29. package/dist/controller/gateway/PublicApiController.js +194 -194
  30. package/dist/controller/gateway/StaticController.d.ts +23 -23
  31. package/dist/controller/gateway/StaticController.js +280 -280
  32. package/dist/controller/helpers.controller.d.ts +36 -36
  33. package/dist/controller/helpers.controller.js +187 -187
  34. package/dist/controller/home.controller.d.ts +9 -9
  35. package/dist/controller/home.controller.js +78 -78
  36. package/dist/controller/manage/AnyApiMangeApi.d.ts +10 -10
  37. package/dist/controller/manage/AnyApiMangeApi.js +98 -98
  38. package/dist/controller/manage/AppLogMangeApi.d.ts +10 -10
  39. package/dist/controller/manage/AppLogMangeApi.js +88 -88
  40. package/dist/controller/manage/AppMangeApi.d.ts +12 -12
  41. package/dist/controller/manage/AppMangeApi.js +101 -101
  42. package/dist/controller/manage/AppPageMangeApi.d.ts +10 -10
  43. package/dist/controller/manage/AppPageMangeApi.js +87 -87
  44. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +10 -10
  45. package/dist/controller/manage/AppSchemaHistoryApi.js +83 -83
  46. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +10 -10
  47. package/dist/controller/manage/CrudMethodsMangeApi.js +84 -84
  48. package/dist/controller/manage/CrudStandardDesignApi.d.ts +46 -46
  49. package/dist/controller/manage/CrudStandardDesignApi.js +367 -367
  50. package/dist/controller/manage/DataDictManageApi.d.ts +17 -17
  51. package/dist/controller/manage/DataDictManageApi.js +165 -165
  52. package/dist/controller/manage/DeployManageApi.d.ts +21 -21
  53. package/dist/controller/manage/DeployManageApi.js +203 -203
  54. package/dist/controller/manage/DocLibManageApi.d.ts +10 -10
  55. package/dist/controller/manage/DocLibManageApi.js +104 -104
  56. package/dist/controller/manage/DocManageApi.d.ts +11 -11
  57. package/dist/controller/manage/DocManageApi.js +130 -130
  58. package/dist/controller/manage/FileManageApi.d.ts +13 -13
  59. package/dist/controller/manage/FileManageApi.js +77 -77
  60. package/dist/controller/manage/FlowConfigManageApi.d.ts +12 -12
  61. package/dist/controller/manage/FlowConfigManageApi.js +109 -109
  62. package/dist/controller/manage/LowCodeTplManageApi.d.ts +13 -13
  63. package/dist/controller/manage/LowCodeTplManageApi.js +86 -86
  64. package/dist/controller/manage/MenuManageApi.d.ts +11 -11
  65. package/dist/controller/manage/MenuManageApi.js +104 -104
  66. package/dist/controller/manage/ProxyApiMangeApi.d.ts +10 -10
  67. package/dist/controller/manage/ProxyApiMangeApi.js +87 -87
  68. package/dist/controller/manage/SuperAdminManageApi.d.ts +24 -24
  69. package/dist/controller/manage/SuperAdminManageApi.js +153 -153
  70. package/dist/controller/manage/SysConfigMangeApi.d.ts +12 -12
  71. package/dist/controller/manage/SysConfigMangeApi.js +133 -133
  72. package/dist/controller/manage/SystemInfoManageApi.d.ts +12 -12
  73. package/dist/controller/manage/SystemInfoManageApi.js +82 -82
  74. package/dist/controller/manage/UserAccountManageApi.d.ts +16 -16
  75. package/dist/controller/manage/UserAccountManageApi.js +153 -153
  76. package/dist/controller/manage/WorkbenchMangeApi.d.ts +11 -11
  77. package/dist/controller/manage/WorkbenchMangeApi.js +106 -106
  78. package/dist/controller/myinfo/AuthController.d.ts +37 -37
  79. package/dist/controller/myinfo/AuthController.js +157 -157
  80. package/dist/controller/myinfo/MyInfoController.d.ts +13 -13
  81. package/dist/controller/myinfo/MyInfoController.js +51 -51
  82. package/dist/controller/render/AppRenderController.d.ts +12 -12
  83. package/dist/controller/render/AppRenderController.js +93 -93
  84. package/dist/controller/test.controller.d.ts +8 -8
  85. package/dist/controller/test.controller.js +51 -51
  86. package/dist/filter/default.filter.d.ts +7 -7
  87. package/dist/filter/default.filter.js +23 -23
  88. package/dist/filter/notfound.filter.d.ts +5 -5
  89. package/dist/filter/notfound.filter.js +20 -20
  90. package/dist/index.d.ts +111 -111
  91. package/dist/index.js +129 -129
  92. package/dist/interface.d.ts +30 -30
  93. package/dist/interface.js +3 -3
  94. package/dist/libs/crud-pro/CrudPro.d.ts +37 -37
  95. package/dist/libs/crud-pro/CrudPro.js +146 -146
  96. package/dist/libs/crud-pro/defaultConfigs.d.ts +4 -4
  97. package/dist/libs/crud-pro/defaultConfigs.js +15 -15
  98. package/dist/libs/crud-pro/exceptions.d.ts +106 -106
  99. package/dist/libs/crud-pro/exceptions.js +119 -119
  100. package/dist/libs/crud-pro/interfaces.d.ts +175 -175
  101. package/dist/libs/crud-pro/interfaces.js +12 -12
  102. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +50 -50
  103. package/dist/libs/crud-pro/models/ExecuteContext.js +87 -87
  104. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +38 -38
  105. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +72 -72
  106. package/dist/libs/crud-pro/models/FuncContext.d.ts +18 -18
  107. package/dist/libs/crud-pro/models/FuncContext.js +6 -6
  108. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +65 -65
  109. package/dist/libs/crud-pro/models/RequestCfgModel.js +81 -81
  110. package/dist/libs/crud-pro/models/RequestModel.d.ts +25 -25
  111. package/dist/libs/crud-pro/models/RequestModel.js +113 -113
  112. package/dist/libs/crud-pro/models/ResModel.d.ts +20 -20
  113. package/dist/libs/crud-pro/models/ResModel.js +2 -2
  114. package/dist/libs/crud-pro/models/ServiceHub.d.ts +20 -20
  115. package/dist/libs/crud-pro/models/ServiceHub.js +2 -2
  116. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +23 -23
  117. package/dist/libs/crud-pro/models/SqlCfgModel.js +40 -40
  118. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +6 -6
  119. package/dist/libs/crud-pro/models/SqlSegArg.js +12 -12
  120. package/dist/libs/crud-pro/models/Transaction.d.ts +50 -50
  121. package/dist/libs/crud-pro/models/Transaction.js +184 -179
  122. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +19 -19
  123. package/dist/libs/crud-pro/models/TransactionMySQL.js +48 -48
  124. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +19 -19
  125. package/dist/libs/crud-pro/models/TransactionPostgres.js +64 -64
  126. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +9 -9
  127. package/dist/libs/crud-pro/models/TransactionSqlServer.js +61 -61
  128. package/dist/libs/crud-pro/models/keys.d.ts +111 -110
  129. package/dist/libs/crud-pro/models/keys.js +156 -154
  130. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +11 -11
  131. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +73 -73
  132. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +9 -9
  133. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +125 -125
  134. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +17 -17
  135. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +224 -224
  136. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +9 -9
  137. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +51 -51
  138. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +13 -13
  139. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +148 -148
  140. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +25 -24
  141. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +385 -355
  142. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +25 -25
  143. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +165 -165
  144. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +32 -32
  145. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +339 -339
  146. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +24 -24
  147. package/dist/libs/crud-pro/services/CrudProServiceBase.js +88 -88
  148. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +9 -9
  149. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +72 -72
  150. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +32 -32
  151. package/dist/libs/crud-pro/services/CurdProServiceHub.js +64 -64
  152. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +9 -9
  153. package/dist/libs/crud-pro/utils/CompareUtils.js +25 -25
  154. package/dist/libs/crud-pro/utils/CrudMonitor.d.ts +9 -9
  155. package/dist/libs/crud-pro/utils/CrudMonitor.js +12 -12
  156. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +9 -9
  157. package/dist/libs/crud-pro/utils/DatabaseName.js +50 -50
  158. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +7 -7
  159. package/dist/libs/crud-pro/utils/DateTimeUtils.js +21 -21
  160. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +19 -19
  161. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +47 -47
  162. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +5 -5
  163. package/dist/libs/crud-pro/utils/MessageParseUtils.js +33 -33
  164. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +40 -40
  165. package/dist/libs/crud-pro/utils/MixinUtils.js +259 -258
  166. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +11 -11
  167. package/dist/libs/crud-pro/utils/ModelUtils.js +54 -54
  168. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +11 -11
  169. package/dist/libs/crud-pro/utils/MultiKeyMap.js +63 -63
  170. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +5 -5
  171. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +29 -29
  172. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +40 -40
  173. package/dist/libs/crud-pro/utils/TypeUtils.js +166 -166
  174. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +3 -3
  175. package/dist/libs/crud-pro/utils/ValidateUtils.js +165 -165
  176. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +3 -3
  177. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +19 -19
  178. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +3 -3
  179. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +20 -20
  180. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +3 -3
  181. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +20 -20
  182. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +4 -4
  183. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +35 -35
  184. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +24 -24
  185. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +2 -2
  186. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +14 -14
  187. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +2 -2
  188. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +14 -14
  189. package/dist/libs/global-config/global-config.d.ts +71 -71
  190. package/dist/libs/global-config/global-config.js +38 -38
  191. package/dist/libs/utils/AsymmetricCrypto.d.ts +76 -76
  192. package/dist/libs/utils/AsymmetricCrypto.js +261 -261
  193. package/dist/libs/utils/base64.d.ts +9 -9
  194. package/dist/libs/utils/base64.js +42 -42
  195. package/dist/libs/utils/common-dto.d.ts +18 -18
  196. package/dist/libs/utils/common-dto.js +40 -40
  197. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  198. package/dist/libs/utils/crypto-utils.js +55 -55
  199. package/dist/libs/utils/errorToString.d.ts +20 -20
  200. package/dist/libs/utils/errorToString.js +79 -79
  201. package/dist/libs/utils/fatcms-request.d.ts +45 -45
  202. package/dist/libs/utils/fatcms-request.js +161 -161
  203. package/dist/libs/utils/format-url.d.ts +17 -17
  204. package/dist/libs/utils/format-url.js +30 -30
  205. package/dist/libs/utils/functions.d.ts +11 -11
  206. package/dist/libs/utils/functions.js +99 -99
  207. package/dist/libs/utils/ordernum-utils.d.ts +22 -22
  208. package/dist/libs/utils/ordernum-utils.js +35 -35
  209. package/dist/libs/utils/parseConfig.d.ts +8 -8
  210. package/dist/libs/utils/parseConfig.js +47 -47
  211. package/dist/libs/utils/parseCreateSql.d.ts +10 -10
  212. package/dist/libs/utils/parseCreateSql.js +87 -87
  213. package/dist/libs/utils/render-utils.d.ts +40 -40
  214. package/dist/libs/utils/render-utils.js +158 -158
  215. package/dist/middleware/forbidden.middleware.d.ts +74 -74
  216. package/dist/middleware/forbidden.middleware.js +318 -307
  217. package/dist/middleware/global.middleware.d.ts +40 -40
  218. package/dist/middleware/global.middleware.js +310 -310
  219. package/dist/middleware/permission.middleware.d.ts +88 -88
  220. package/dist/middleware/permission.middleware.js +145 -145
  221. package/dist/middleware/rediscache.middleware.d.ts +28 -28
  222. package/dist/middleware/rediscache.middleware.js +114 -114
  223. package/dist/middleware/redislock.middleware.d.ts +29 -29
  224. package/dist/middleware/redislock.middleware.js +106 -106
  225. package/dist/middleware/tx.middleware.d.ts +55 -55
  226. package/dist/middleware/tx.middleware.js +83 -83
  227. package/dist/models/AsyncTaskModel.d.ts +74 -74
  228. package/dist/models/AsyncTaskModel.js +31 -31
  229. package/dist/models/FlowModel.d.ts +227 -227
  230. package/dist/models/FlowModel.js +53 -53
  231. package/dist/models/RedisKeys.d.ts +15 -15
  232. package/dist/models/RedisKeys.js +18 -18
  233. package/dist/models/SystemEntities.d.ts +118 -117
  234. package/dist/models/SystemEntities.js +18 -17
  235. package/dist/models/SystemPerm.d.ts +96 -96
  236. package/dist/models/SystemPerm.js +101 -101
  237. package/dist/models/SystemTables.d.ts +25 -25
  238. package/dist/models/SystemTables.js +28 -28
  239. package/dist/models/WorkbenchInfoTools.d.ts +7 -7
  240. package/dist/models/WorkbenchInfoTools.js +20 -20
  241. package/dist/models/bizmodels.d.ts +150 -150
  242. package/dist/models/bizmodels.js +62 -62
  243. package/dist/models/contextLogger.d.ts +27 -27
  244. package/dist/models/contextLogger.js +119 -119
  245. package/dist/models/devops.d.ts +12 -12
  246. package/dist/models/devops.js +19 -19
  247. package/dist/models/userSession.d.ts +67 -67
  248. package/dist/models/userSession.js +179 -179
  249. package/dist/schedule/anonymousContext.d.ts +15 -15
  250. package/dist/schedule/anonymousContext.js +74 -74
  251. package/dist/schedule/index.d.ts +4 -4
  252. package/dist/schedule/index.js +10 -10
  253. package/dist/schedule/runSchedule.d.ts +12 -12
  254. package/dist/schedule/runSchedule.js +68 -68
  255. package/dist/schedule/scheduleNames.d.ts +15 -15
  256. package/dist/schedule/scheduleNames.js +19 -19
  257. package/dist/service/AuthService.d.ts +56 -56
  258. package/dist/service/AuthService.js +251 -248
  259. package/dist/service/EnumInfoService.d.ts +30 -30
  260. package/dist/service/EnumInfoService.js +97 -97
  261. package/dist/service/FileCenterService.d.ts +64 -64
  262. package/dist/service/FileCenterService.js +422 -422
  263. package/dist/service/SysAppService.d.ts +15 -15
  264. package/dist/service/SysAppService.js +108 -108
  265. package/dist/service/SysConfigService.d.ts +10 -10
  266. package/dist/service/SysConfigService.js +64 -64
  267. package/dist/service/SysDictDataService.d.ts +9 -9
  268. package/dist/service/SysDictDataService.js +72 -72
  269. package/dist/service/SysMenuService.d.ts +51 -51
  270. package/dist/service/SysMenuService.js +58 -58
  271. package/dist/service/UserAccountService.d.ts +23 -23
  272. package/dist/service/UserAccountService.js +107 -107
  273. package/dist/service/UserSessionService.d.ts +43 -43
  274. package/dist/service/UserSessionService.js +163 -163
  275. package/dist/service/VisitStatService.d.ts +14 -14
  276. package/dist/service/VisitStatService.js +161 -161
  277. package/dist/service/WorkbenchService.d.ts +59 -59
  278. package/dist/service/WorkbenchService.js +249 -249
  279. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  280. package/dist/service/anyapi/AnyApiSandboxService.js +110 -110
  281. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  282. package/dist/service/anyapi/AnyApiService.js +181 -181
  283. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -50
  284. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -287
  285. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -7
  286. package/dist/service/asyncTask/AsyncTaskService.js +34 -34
  287. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -10
  288. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -2
  289. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -7
  290. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -216
  291. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -36
  292. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -141
  293. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -46
  294. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -135
  295. package/dist/service/base/ApiBaseService.d.ts +22 -22
  296. package/dist/service/base/ApiBaseService.js +60 -60
  297. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  298. package/dist/service/base/ApiRateLimiter.js +51 -51
  299. package/dist/service/base/BaseService.d.ts +46 -45
  300. package/dist/service/base/BaseService.js +131 -127
  301. package/dist/service/base/cache/CacheServiceFactory.d.ts +26 -26
  302. package/dist/service/base/cache/CacheServiceFactory.js +122 -122
  303. package/dist/service/base/cache/CtxCache.d.ts +18 -18
  304. package/dist/service/base/cache/CtxCache.js +37 -37
  305. package/dist/service/base/cache/DiskCache.d.ts +19 -19
  306. package/dist/service/base/cache/DiskCache.js +81 -81
  307. package/dist/service/base/cache/MemoryCache.d.ts +12 -12
  308. package/dist/service/base/cache/MemoryCache.js +58 -58
  309. package/dist/service/base/cache/NoneCache.d.ts +10 -10
  310. package/dist/service/base/cache/NoneCache.js +19 -19
  311. package/dist/service/base/cache/RedisCache.d.ts +14 -14
  312. package/dist/service/base/cache/RedisCache.js +31 -31
  313. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  314. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  315. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  316. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  317. package/dist/service/crudstd/CrudStdRelationService.d.ts +11 -11
  318. package/dist/service/crudstd/CrudStdRelationService.js +179 -179
  319. package/dist/service/crudstd/CrudStdService.d.ts +59 -59
  320. package/dist/service/crudstd/CrudStdService.js +348 -348
  321. package/dist/service/curd/CrudProQuick.d.ts +60 -60
  322. package/dist/service/curd/CrudProQuick.js +167 -167
  323. package/dist/service/curd/CurdMixByAccountService.d.ts +14 -14
  324. package/dist/service/curd/CurdMixByAccountService.js +166 -166
  325. package/dist/service/curd/CurdMixByDictService.d.ts +12 -12
  326. package/dist/service/curd/CurdMixByDictService.js +114 -114
  327. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +30 -30
  328. package/dist/service/curd/CurdMixByLinkToCustomService.js +209 -209
  329. package/dist/service/curd/CurdMixBySysConfigService.d.ts +13 -13
  330. package/dist/service/curd/CurdMixBySysConfigService.js +116 -116
  331. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +11 -11
  332. package/dist/service/curd/CurdMixByWorkbenchService.js +80 -80
  333. package/dist/service/curd/CurdMixService.d.ts +28 -28
  334. package/dist/service/curd/CurdMixService.js +100 -100
  335. package/dist/service/curd/CurdMixUtils.d.ts +57 -57
  336. package/dist/service/curd/CurdMixUtils.js +331 -331
  337. package/dist/service/curd/CurdProService.d.ts +32 -32
  338. package/dist/service/curd/CurdProService.js +215 -215
  339. package/dist/service/curd/fixCfgModel.d.ts +3 -3
  340. package/dist/service/curd/fixCfgModel.js +104 -104
  341. package/dist/service/curd/fixSoftDelete.d.ts +6 -6
  342. package/dist/service/curd/fixSoftDelete.js +43 -43
  343. package/dist/service/flow/FlowConfigService.d.ts +41 -41
  344. package/dist/service/flow/FlowConfigService.js +95 -95
  345. package/dist/service/flow/FlowInstanceCrudService.d.ts +35 -35
  346. package/dist/service/flow/FlowInstanceCrudService.js +257 -257
  347. package/dist/service/flow/FlowInstanceService.d.ts +88 -88
  348. package/dist/service/flow/FlowInstanceService.js +451 -451
  349. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  350. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  351. package/dist/service/proxyapi/ProxyApiService.d.ts +61 -61
  352. package/dist/service/proxyapi/ProxyApiService.js +317 -297
  353. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  354. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  355. package/dist/service/proxyapi/RouteHandler.d.ts +6 -5
  356. package/dist/service/proxyapi/RouteHandler.js +9 -9
  357. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  358. package/dist/service/proxyapi/RouteTrie.js +64 -63
  359. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  360. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  361. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  362. package/dist/service/proxyapi/WeightedRoundRobin.js +33 -32
  363. package/index.d.ts +10 -10
  364. package/package.json +87 -87
  365. package/src/libs/crud-pro/models/Transaction.ts +5 -1
  366. package/src/libs/crud-pro/models/keys.ts +6 -2
  367. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +37 -0
  368. package/src/libs/crud-pro/utils/CrudMonitor.ts +13 -13
  369. package/src/libs/crud-pro/utils/MixinUtils.ts +11 -10
  370. package/src/libs/utils/AsymmetricCrypto.ts +307 -307
  371. package/src/libs/utils/format-url.ts +29 -29
  372. package/src/libs/utils/render-utils.ts +223 -223
  373. package/src/middleware/forbidden.middleware.ts +17 -7
  374. package/src/middleware/global.middleware.ts +1 -1
  375. package/src/models/SystemEntities.ts +1 -0
  376. package/src/models/WorkbenchInfoTools.ts +19 -19
  377. package/src/service/AuthService.ts +3 -0
  378. package/src/service/SysAppService.ts +103 -103
  379. package/src/service/SysDictDataService.ts +63 -63
  380. package/src/service/SysMenuService.ts +87 -87
  381. package/src/service/WorkbenchService.ts +279 -279
  382. package/src/service/base/BaseService.ts +5 -0
  383. package/src/service/base/cache/CacheServiceFactory.ts +135 -135
  384. package/src/service/base/cache/CtxCache.ts +45 -45
  385. package/src/service/base/cache/DiskCache.ts +90 -90
  386. package/src/service/base/cache/MemoryCache.ts +68 -68
  387. package/src/service/base/cache/NoneCache.ts +24 -24
  388. package/src/service/base/cache/RedisCache.ts +41 -41
  389. package/src/service/crudstd/CrudStdService.ts +2 -1
  390. package/src/service/curd/CurdMixByAccountService.ts +177 -177
  391. package/src/service/curd/fixSoftDelete.ts +58 -58
  392. package/src/service/proxyapi/ProxyApiService.ts +22 -1
  393. package/src/service/proxyapi/RouteHandler.ts +4 -2
  394. package/src/service/proxyapi/RouteTrie.ts +1 -1
  395. package/src/service/proxyapi/WeightedRoundRobin.ts +2 -1
  396. package/tsconfig.json +32 -32
@@ -1,339 +1,339 @@
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 ORDER_BY_TYPE_ARR = ['asc', 'desc'];
215
- const orderByArr = orderBys.map(orderBy => {
216
- const orderType = (orderBy.orderType || 'asc').toLowerCase();
217
- if (!ORDER_BY_TYPE_ARR.includes(orderType)) {
218
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_ORDER_BY_TYPE_ERROR, 'orderType must be asc or desc : ' + orderType);
219
- }
220
- return (0, convertColumnName_1.toSqlColumnName)(orderBy.fieldName, sqlCfgModel) + ' ' + orderType;
221
- });
222
- const sql = 'order by ' + orderByArr.join(',');
223
- return new SqlSegArg_1.SqlSegArg(sql);
224
- }
225
- generatePickResAs(req, world) {
226
- return new SqlSegArg_1.SqlSegArg(' ? ', [
227
- {
228
- ___GENERATE_GET_RES_ATTR___: world,
229
- },
230
- ]);
231
- }
232
- generateGetAttr(req, word) {
233
- const attrName = MixinUtils_1.MixinUtils.removeStringPrefix(word, '@@');
234
- if (MixinUtils_1.MixinUtils.isEmpty(attrName)) {
235
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_GET_ATTR_NAME_EMPTY, word);
236
- }
237
- const dataValue = req.getJsonObjectValue(attrName);
238
- if (typeof dataValue === 'undefined' || !TypeUtils_1.TypeUtils.isBasicType(dataValue)) {
239
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_GET_ATTR_VALUE_ERROR, word);
240
- }
241
- return new SqlSegArg_1.SqlSegArg(' ? ', [dataValue]);
242
- }
243
- generateDataUpdate(req, sqlCfgModel, dataName) {
244
- const data = req.getCondOrDataJsonObject(dataName);
245
- if (MixinUtils_1.MixinUtils.isEmpty(data)) {
246
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.DATA_GET_DATA_EMPTY_ON_UPDATE, dataName);
247
- }
248
- const keys = Object.keys(data).sort();
249
- const sqlList = [];
250
- const argList = [];
251
- for (let i = 0; i < keys.length; i++) {
252
- const key = keys[i];
253
- const arg = data[key];
254
- if (SqlFuncUtils_1.sqlFuncUtils.isSqlFuncArg(arg)) {
255
- const funcSQL = SqlFuncUtils_1.sqlFuncUtils.toFuncSQL(arg);
256
- sqlList.push((0, convertColumnName_1.toSqlColumnName)(key, sqlCfgModel) + '= ' + funcSQL);
257
- }
258
- else {
259
- sqlList.push((0, convertColumnName_1.toSqlColumnName)(key, sqlCfgModel) + '= ?');
260
- argList.push(arg);
261
- }
262
- }
263
- const sql = sqlList.join(',');
264
- return new SqlSegArg_1.SqlSegArg(sql, argList);
265
- }
266
- generateDataAsInsertValues(req, dataName) {
267
- const data = req.getCondOrDataJsonObject(dataName);
268
- if (MixinUtils_1.MixinUtils.isEmpty(data)) {
269
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_VALUES, dataName);
270
- }
271
- const keys = Object.keys(data).sort();
272
- const sqlList = [];
273
- const argList = [];
274
- for (let i = 0; i < keys.length; i++) {
275
- const key = keys[i];
276
- const arg = data[key];
277
- // 如 data: {xxxTime: {$byFunc:"NOW()"}}
278
- if (SqlFuncUtils_1.sqlFuncUtils.isSqlFuncArg(arg)) {
279
- const funcSQL = SqlFuncUtils_1.sqlFuncUtils.toFuncSQL(arg); // values( ? , ? , NOW() , ?)
280
- sqlList.push(funcSQL);
281
- }
282
- else {
283
- sqlList.push('?');
284
- argList.push(arg);
285
- }
286
- }
287
- const sql = sqlList.join(','); // "?,?,?,?"
288
- return new SqlSegArg_1.SqlSegArg(sql, argList);
289
- }
290
- generateSqlJavaFunction(requestCfg, tmpFuncName) {
291
- const exeCtx = this.getExecuteContext();
292
- const functionCfg = requestCfg.functionCfg;
293
- if (MixinUtils_1.MixinUtils.isEmpty(functionCfg)) {
294
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_SQL_FUNCTION_EMPTY, tmpFuncName);
295
- }
296
- const tmpFunCfg = functionCfg[tmpFuncName];
297
- if (ModelUtils_1.ModelUtils.checkFuncCfgValid(tmpFunCfg)) {
298
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_VALIDATE_CUSTOM_FUNCTION_EMPTY, tmpFuncName);
299
- }
300
- const exeFunCtx = new FuncContext_1.FuncContext();
301
- exeFunCtx.currentValue = null;
302
- exeFunCtx.reqModel = exeCtx.getReqModel();
303
- exeFunCtx.resModel = exeCtx.getResModel();
304
- const dataValue = this.serviceHub.executeFuncCfg(tmpFunCfg, exeFunCtx);
305
- return new SqlSegArg_1.SqlSegArg(' ? ', [dataValue]);
306
- }
307
- /**
308
- * 不会返回空。
309
- * @param sqlCfgModel
310
- * @private
311
- */
312
- async generateCfgColumns(sqlCfgModel) {
313
- const tableMeta = await this.serviceHub.getTableMeta(sqlCfgModel);
314
- const tableColumns = tableMeta.tableColumns;
315
- const cfgColumns = sqlCfgModel.columns || [];
316
- // 没有配置: 全量
317
- if (MixinUtils_1.MixinUtils.isEmpty(cfgColumns)) {
318
- return tableColumns;
319
- }
320
- // 黑名单:排除法
321
- if (isAnyStartWithExclude(cfgColumns)) {
322
- const excludeColumns = cfgColumns.filter(c => {
323
- return c.startsWith('!');
324
- });
325
- const excludeColumnsSet = new Set(excludeColumns);
326
- const result = [];
327
- for (let i = 0; i < tableColumns.length; i++) {
328
- const tableColumn = tableColumns[i];
329
- if (!excludeColumnsSet.has('!' + tableColumn)) {
330
- result.push(tableColumn);
331
- }
332
- }
333
- return result;
334
- }
335
- // 白名单
336
- return cfgColumns;
337
- }
338
- }
339
- 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 ORDER_BY_TYPE_ARR = ['asc', 'desc'];
215
+ const orderByArr = orderBys.map(orderBy => {
216
+ const orderType = (orderBy.orderType || 'asc').toLowerCase();
217
+ if (!ORDER_BY_TYPE_ARR.includes(orderType)) {
218
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_ORDER_BY_TYPE_ERROR, 'orderType must be asc or desc : ' + orderType);
219
+ }
220
+ return (0, convertColumnName_1.toSqlColumnName)(orderBy.fieldName, sqlCfgModel) + ' ' + orderType;
221
+ });
222
+ const sql = 'order by ' + orderByArr.join(',');
223
+ return new SqlSegArg_1.SqlSegArg(sql);
224
+ }
225
+ generatePickResAs(req, world) {
226
+ return new SqlSegArg_1.SqlSegArg(' ? ', [
227
+ {
228
+ ___GENERATE_GET_RES_ATTR___: world,
229
+ },
230
+ ]);
231
+ }
232
+ generateGetAttr(req, word) {
233
+ const attrName = MixinUtils_1.MixinUtils.removeStringPrefix(word, '@@');
234
+ if (MixinUtils_1.MixinUtils.isEmpty(attrName)) {
235
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_GET_ATTR_NAME_EMPTY, word);
236
+ }
237
+ const dataValue = req.getJsonObjectValue(attrName);
238
+ if (typeof dataValue === 'undefined' || !TypeUtils_1.TypeUtils.isBasicType(dataValue)) {
239
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_GET_ATTR_VALUE_ERROR, word);
240
+ }
241
+ return new SqlSegArg_1.SqlSegArg(' ? ', [dataValue]);
242
+ }
243
+ generateDataUpdate(req, sqlCfgModel, dataName) {
244
+ const data = req.getCondOrDataJsonObject(dataName);
245
+ if (MixinUtils_1.MixinUtils.isEmpty(data)) {
246
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.DATA_GET_DATA_EMPTY_ON_UPDATE, dataName);
247
+ }
248
+ const keys = Object.keys(data).sort();
249
+ const sqlList = [];
250
+ const argList = [];
251
+ for (let i = 0; i < keys.length; i++) {
252
+ const key = keys[i];
253
+ const arg = data[key];
254
+ if (SqlFuncUtils_1.sqlFuncUtils.isSqlFuncArg(arg)) {
255
+ const funcSQL = SqlFuncUtils_1.sqlFuncUtils.toFuncSQL(arg);
256
+ sqlList.push((0, convertColumnName_1.toSqlColumnName)(key, sqlCfgModel) + '= ' + funcSQL);
257
+ }
258
+ else {
259
+ sqlList.push((0, convertColumnName_1.toSqlColumnName)(key, sqlCfgModel) + '= ?');
260
+ argList.push(arg);
261
+ }
262
+ }
263
+ const sql = sqlList.join(',');
264
+ return new SqlSegArg_1.SqlSegArg(sql, argList);
265
+ }
266
+ generateDataAsInsertValues(req, dataName) {
267
+ const data = req.getCondOrDataJsonObject(dataName);
268
+ if (MixinUtils_1.MixinUtils.isEmpty(data)) {
269
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.DATA_GET_DATA_EMPTY_ON_INSERT_VALUES, dataName);
270
+ }
271
+ const keys = Object.keys(data).sort();
272
+ const sqlList = [];
273
+ const argList = [];
274
+ for (let i = 0; i < keys.length; i++) {
275
+ const key = keys[i];
276
+ const arg = data[key];
277
+ // 如 data: {xxxTime: {$byFunc:"NOW()"}}
278
+ if (SqlFuncUtils_1.sqlFuncUtils.isSqlFuncArg(arg)) {
279
+ const funcSQL = SqlFuncUtils_1.sqlFuncUtils.toFuncSQL(arg); // values( ? , ? , NOW() , ?)
280
+ sqlList.push(funcSQL);
281
+ }
282
+ else {
283
+ sqlList.push('?');
284
+ argList.push(arg);
285
+ }
286
+ }
287
+ const sql = sqlList.join(','); // "?,?,?,?"
288
+ return new SqlSegArg_1.SqlSegArg(sql, argList);
289
+ }
290
+ generateSqlJavaFunction(requestCfg, tmpFuncName) {
291
+ const exeCtx = this.getExecuteContext();
292
+ const functionCfg = requestCfg.functionCfg;
293
+ if (MixinUtils_1.MixinUtils.isEmpty(functionCfg)) {
294
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_SQL_FUNCTION_EMPTY, tmpFuncName);
295
+ }
296
+ const tmpFunCfg = functionCfg[tmpFuncName];
297
+ if (ModelUtils_1.ModelUtils.checkFuncCfgValid(tmpFunCfg)) {
298
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_VALIDATE_CUSTOM_FUNCTION_EMPTY, tmpFuncName);
299
+ }
300
+ const exeFunCtx = new FuncContext_1.FuncContext();
301
+ exeFunCtx.currentValue = null;
302
+ exeFunCtx.reqModel = exeCtx.getReqModel();
303
+ exeFunCtx.resModel = exeCtx.getResModel();
304
+ const dataValue = this.serviceHub.executeFuncCfg(tmpFunCfg, exeFunCtx);
305
+ return new SqlSegArg_1.SqlSegArg(' ? ', [dataValue]);
306
+ }
307
+ /**
308
+ * 不会返回空。
309
+ * @param sqlCfgModel
310
+ * @private
311
+ */
312
+ async generateCfgColumns(sqlCfgModel) {
313
+ const tableMeta = await this.serviceHub.getTableMeta(sqlCfgModel);
314
+ const tableColumns = tableMeta.tableColumns;
315
+ const cfgColumns = sqlCfgModel.columns || [];
316
+ // 没有配置: 全量
317
+ if (MixinUtils_1.MixinUtils.isEmpty(cfgColumns)) {
318
+ return tableColumns;
319
+ }
320
+ // 黑名单:排除法
321
+ if (isAnyStartWithExclude(cfgColumns)) {
322
+ const excludeColumns = cfgColumns.filter(c => {
323
+ return c.startsWith('!');
324
+ });
325
+ const excludeColumnsSet = new Set(excludeColumns);
326
+ const result = [];
327
+ for (let i = 0; i < tableColumns.length; i++) {
328
+ const tableColumn = tableColumns[i];
329
+ if (!excludeColumnsSet.has('!' + tableColumn)) {
330
+ result.push(tableColumn);
331
+ }
332
+ }
333
+ return result;
334
+ }
335
+ // 白名单
336
+ return cfgColumns;
337
+ }
338
+ }
339
+ exports.CrudProOriginToExecuteSql = CrudProOriginToExecuteSql;