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,25 +1,25 @@
1
- import { CrudProServiceBase } from './CrudProServiceBase';
2
- declare class CrudProGenSqlService extends CrudProServiceBase {
3
- generateSQLList(): Promise<void>;
4
- private generateOriginSql;
5
- /**
6
- * 删除语句
7
- * @param cfgModel
8
- * @private
9
- */
10
- private generateOriginSqlForDelete;
11
- /**
12
- * 创建插入OR更新语句
13
- * @param cfgModel
14
- * @private
15
- */
16
- private generateOriginSqlForDuplicateInsert;
17
- /**
18
- * 创建插入语句
19
- * @param cfgModel
20
- * @private
21
- */
22
- private generateOriginSqlForInsert;
23
- private generateExecuteSql;
24
- }
25
- export { CrudProGenSqlService };
1
+ import { CrudProServiceBase } from './CrudProServiceBase';
2
+ declare class CrudProGenSqlService extends CrudProServiceBase {
3
+ generateSQLList(): Promise<void>;
4
+ private generateOriginSql;
5
+ /**
6
+ * 删除语句
7
+ * @param cfgModel
8
+ * @private
9
+ */
10
+ private generateOriginSqlForDelete;
11
+ /**
12
+ * 创建插入OR更新语句
13
+ * @param cfgModel
14
+ * @private
15
+ */
16
+ private generateOriginSqlForDuplicateInsert;
17
+ /**
18
+ * 创建插入语句
19
+ * @param cfgModel
20
+ * @private
21
+ */
22
+ private generateOriginSqlForInsert;
23
+ private generateExecuteSql;
24
+ }
25
+ export { CrudProGenSqlService };
@@ -1,165 +1,165 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CrudProGenSqlService = void 0;
4
- const CrudProServiceBase_1 = require("./CrudProServiceBase");
5
- const exceptions_1 = require("../exceptions");
6
- const MixinUtils_1 = require("../utils/MixinUtils");
7
- const keys_1 = require("../models/keys");
8
- const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils_1.MixinUtils;
9
- class CrudProGenSqlService extends CrudProServiceBase_1.CrudProServiceBase {
10
- async generateSQLList() {
11
- const exeCtx = this.getExecuteContext();
12
- const reqCfg = exeCtx.getCfgModel();
13
- const sqlSimpleName = reqCfg.sqlSimpleName;
14
- // 简单模式
15
- const isSimpleMode = isNotEmpty(sqlSimpleName) && sqlSimpleName.startsWith('SIMPLE_');
16
- // 拼接简单模式的SQL
17
- if (isSimpleMode) {
18
- this.generateOriginSql();
19
- }
20
- await this.generateExecuteSql();
21
- }
22
- generateOriginSql() {
23
- const exeCtx = this.getExecuteContext();
24
- const cfgModel = exeCtx.getCfgModel();
25
- const simpleSqlName = cfgModel.sqlSimpleName;
26
- // 只有当设置了simpleSqlName时,才启用内置的SQL生成
27
- if (isEmpty(simpleSqlName)) {
28
- return;
29
- }
30
- cfgModel.sqlCfgList = [];
31
- let sql1 = null;
32
- let sql2 = null;
33
- let sql3 = null;
34
- if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY, simpleSqlName)) {
35
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit';
36
- cfgModel.addSqlCfgModel('rows', sql1);
37
- }
38
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_ONE, simpleSqlName)) {
39
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys limit 1';
40
- cfgModel.addSqlCfgModel('row', sql1, keys_1.KeysOfSqlResPicker.RESULT_FIRST_ROW);
41
- }
42
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_COUNT, simpleSqlName)) {
43
- sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition';
44
- cfgModel.addSqlCfgModel('total_count', sql1, keys_1.KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
45
- }
46
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE, simpleSqlName)) {
47
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit ';
48
- sql2 = 'select count(0) as total_count from @@table where @@asWhere:condition';
49
- cfgModel.addSqlCfgModel('rows', sql1);
50
- cfgModel.addSqlCfgModel('total_count', sql2, keys_1.KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
51
- }
52
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_DELETE, simpleSqlName)) {
53
- sql1 = this.generateOriginSqlForDelete(cfgModel);
54
- cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
55
- }
56
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_INSERT, simpleSqlName)) {
57
- sql1 = this.generateOriginSqlForInsert(cfgModel);
58
- cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
59
- }
60
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE, simpleSqlName)) {
61
- sql1 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
62
- cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
63
- }
64
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE, simpleSqlName)) {
65
- sql1 = this.generateOriginSqlForDuplicateInsert(cfgModel);
66
- cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
67
- }
68
- else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE, simpleSqlName)) {
69
- sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition ';
70
- sql2 = 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )';
71
- sql3 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
72
- const insertWhen2 = {
73
- functionName: 'eq',
74
- functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
75
- };
76
- const updateWhen3 = {
77
- functionName: 'gt',
78
- functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
79
- };
80
- cfgModel.addSqlCfgModel('total_count', sql1, keys_1.KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
81
- cfgModel.addSqlCfgModel('insert_affected', sql2, keys_1.KeysOfSqlResPicker.UPDATE_RESULT, insertWhen2);
82
- cfgModel.addSqlCfgModel('update_affected', sql3, keys_1.KeysOfSqlResPicker.UPDATE_RESULT, updateWhen3);
83
- }
84
- if (isEmpty(sql1)) {
85
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_NOT_SUPPORT_THE_SIMPLE_SQL, simpleSqlName);
86
- }
87
- }
88
- /**
89
- * 删除语句
90
- * @param cfgModel
91
- * @private
92
- */
93
- generateOriginSqlForDelete(cfgModel) {
94
- if (cfgModel.sqlDbType === keys_1.SqlDbType.postgres) {
95
- return 'delete from @@table where @@asWhere:condition ';
96
- }
97
- if (cfgModel.sqlDbType === keys_1.SqlDbType.sqlserver) {
98
- return 'delete from @@table where @@asWhere:condition ';
99
- }
100
- return 'delete from @@table where @@asWhere:condition limit 100 '; // 删除操作,不能一次性删除太多
101
- }
102
- /**
103
- * 创建插入OR更新语句
104
- * @param cfgModel
105
- * @private
106
- */
107
- generateOriginSqlForDuplicateInsert(cfgModel) {
108
- if (cfgModel.sqlDbType === keys_1.SqlDbType.postgres) {
109
- const uniqueColumn = cfgModel.uniqueColumn; // id
110
- if (!Array.isArray(uniqueColumn) || uniqueColumn.length === 0) {
111
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_ERROR_POSTGRES_UNIQUE_COLUMNS_NULL);
112
- }
113
- const unique_column = uniqueColumn
114
- .map(s => {
115
- return `"${s}"`;
116
- })
117
- .join(',');
118
- return `insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) ON CONFLICT (${unique_column}) DO UPDATE set @@asUpdate:data `; // 关键字的前后,必须有空格
119
- }
120
- if (cfgModel.sqlDbType === keys_1.SqlDbType.sqlserver) {
121
- const uniqueColumn = cfgModel.uniqueColumn; // id
122
- if (uniqueColumn.length !== 1) {
123
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_UNIQUE_COLUMN_COUNT_MUST_ONE);
124
- }
125
- const uniqueColumnStr = uniqueColumn[0];
126
- const uniqueColumnVal = '@@data.' + uniqueColumnStr;
127
- const sql = '' + `IF EXISTS (SELECT 1 FROM @@table WHERE [${uniqueColumnStr}] = ${uniqueColumnVal})` + 'BEGIN\n' + ' UPDATE @@table\n' + ' SET @@asUpdate:data\n' + ` WHERE [${uniqueColumnStr}] = ${uniqueColumnVal} ;\n` + 'END\n' + 'ELSE\n' + 'BEGIN\n' + ' INSERT INTO @@table ( @@asInsertKeys:data )\n' + ' VALUES ( @@asInsertValues:data );\n' + 'END';
128
- return sql;
129
- }
130
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) on duplicate key update @@asUpdate:data '; // 关键字的前后,必须有空格
131
- }
132
- /**
133
- * 创建插入语句
134
- * @param cfgModel
135
- * @private
136
- */
137
- generateOriginSqlForInsert(cfgModel) {
138
- if (cfgModel.sqlDbType === keys_1.SqlDbType.postgres) {
139
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) RETURNING * ';
140
- }
141
- if (cfgModel.sqlDbType === keys_1.SqlDbType.sqlserver) {
142
- return 'insert into @@table ( @@asInsertKeys:data ) OUTPUT INSERTED.* values( @@asInsertValues:data ) ';
143
- }
144
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )'; // 关键字的前后,必须有空格
145
- }
146
- async generateExecuteSql() {
147
- const exeCtx = this.getExecuteContext();
148
- const reqCfgModel = exeCtx.getCfgModel();
149
- const sqlCfgList = reqCfgModel.sqlCfgList || [];
150
- const { sqlTable, sqlSchema, sqlDatabase, sqlDbType, maxLimit, columns, columnsRelation } = reqCfgModel;
151
- for (let i = 0; i < sqlCfgList.length; i++) {
152
- const sqlCfgModel = sqlCfgList[i];
153
- sqlCfgModel.sqlDbType = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlDbType, sqlDbType);
154
- sqlCfgModel.sqlDatabase = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlDatabase, sqlDatabase);
155
- sqlCfgModel.sqlSchema = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlSchema, sqlSchema);
156
- sqlCfgModel.sqlTable = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlTable, sqlTable);
157
- sqlCfgModel.maxLimit = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.maxLimit, maxLimit);
158
- sqlCfgModel.columns = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.columns, columns);
159
- sqlCfgModel.columnsRelation = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.columnsRelation, columnsRelation);
160
- await this.serviceHub.convertOriginToExecuteSql(sqlCfgModel);
161
- exeCtx.getSqlCfgModels().push(sqlCfgModel);
162
- }
163
- }
164
- }
165
- exports.CrudProGenSqlService = CrudProGenSqlService;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CrudProGenSqlService = void 0;
4
+ const CrudProServiceBase_1 = require("./CrudProServiceBase");
5
+ const exceptions_1 = require("../exceptions");
6
+ const MixinUtils_1 = require("../utils/MixinUtils");
7
+ const keys_1 = require("../models/keys");
8
+ const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils_1.MixinUtils;
9
+ class CrudProGenSqlService extends CrudProServiceBase_1.CrudProServiceBase {
10
+ async generateSQLList() {
11
+ const exeCtx = this.getExecuteContext();
12
+ const reqCfg = exeCtx.getCfgModel();
13
+ const sqlSimpleName = reqCfg.sqlSimpleName;
14
+ // 简单模式
15
+ const isSimpleMode = isNotEmpty(sqlSimpleName) && sqlSimpleName.startsWith('SIMPLE_');
16
+ // 拼接简单模式的SQL
17
+ if (isSimpleMode) {
18
+ this.generateOriginSql();
19
+ }
20
+ await this.generateExecuteSql();
21
+ }
22
+ generateOriginSql() {
23
+ const exeCtx = this.getExecuteContext();
24
+ const cfgModel = exeCtx.getCfgModel();
25
+ const simpleSqlName = cfgModel.sqlSimpleName;
26
+ // 只有当设置了simpleSqlName时,才启用内置的SQL生成
27
+ if (isEmpty(simpleSqlName)) {
28
+ return;
29
+ }
30
+ cfgModel.sqlCfgList = [];
31
+ let sql1 = null;
32
+ let sql2 = null;
33
+ let sql3 = null;
34
+ if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY, simpleSqlName)) {
35
+ sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit';
36
+ cfgModel.addSqlCfgModel('rows', sql1);
37
+ }
38
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_ONE, simpleSqlName)) {
39
+ sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys limit 1';
40
+ cfgModel.addSqlCfgModel('row', sql1, keys_1.KeysOfSqlResPicker.RESULT_FIRST_ROW);
41
+ }
42
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_COUNT, simpleSqlName)) {
43
+ sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition';
44
+ cfgModel.addSqlCfgModel('total_count', sql1, keys_1.KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
45
+ }
46
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_PAGE, simpleSqlName)) {
47
+ sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit ';
48
+ sql2 = 'select count(0) as total_count from @@table where @@asWhere:condition';
49
+ cfgModel.addSqlCfgModel('rows', sql1);
50
+ cfgModel.addSqlCfgModel('total_count', sql2, keys_1.KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
51
+ }
52
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_DELETE, simpleSqlName)) {
53
+ sql1 = this.generateOriginSqlForDelete(cfgModel);
54
+ cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
55
+ }
56
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_INSERT, simpleSqlName)) {
57
+ sql1 = this.generateOriginSqlForInsert(cfgModel);
58
+ cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
59
+ }
60
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE, simpleSqlName)) {
61
+ sql1 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
62
+ cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
63
+ }
64
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE, simpleSqlName)) {
65
+ sql1 = this.generateOriginSqlForDuplicateInsert(cfgModel);
66
+ cfgModel.addSqlCfgModel('affected', sql1, keys_1.KeysOfSqlResPicker.UPDATE_RESULT);
67
+ }
68
+ else if (equalsIgnoreCase(keys_1.KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE, simpleSqlName)) {
69
+ sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition ';
70
+ sql2 = 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )';
71
+ sql3 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
72
+ const insertWhen2 = {
73
+ functionName: 'eq',
74
+ functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
75
+ };
76
+ const updateWhen3 = {
77
+ functionName: 'gt',
78
+ functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
79
+ };
80
+ cfgModel.addSqlCfgModel('total_count', sql1, keys_1.KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
81
+ cfgModel.addSqlCfgModel('insert_affected', sql2, keys_1.KeysOfSqlResPicker.UPDATE_RESULT, insertWhen2);
82
+ cfgModel.addSqlCfgModel('update_affected', sql3, keys_1.KeysOfSqlResPicker.UPDATE_RESULT, updateWhen3);
83
+ }
84
+ if (isEmpty(sql1)) {
85
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_NOT_SUPPORT_THE_SIMPLE_SQL, simpleSqlName);
86
+ }
87
+ }
88
+ /**
89
+ * 删除语句
90
+ * @param cfgModel
91
+ * @private
92
+ */
93
+ generateOriginSqlForDelete(cfgModel) {
94
+ if (cfgModel.sqlDbType === keys_1.SqlDbType.postgres) {
95
+ return 'delete from @@table where @@asWhere:condition ';
96
+ }
97
+ if (cfgModel.sqlDbType === keys_1.SqlDbType.sqlserver) {
98
+ return 'delete from @@table where @@asWhere:condition ';
99
+ }
100
+ return 'delete from @@table where @@asWhere:condition limit 100 '; // 删除操作,不能一次性删除太多
101
+ }
102
+ /**
103
+ * 创建插入OR更新语句
104
+ * @param cfgModel
105
+ * @private
106
+ */
107
+ generateOriginSqlForDuplicateInsert(cfgModel) {
108
+ if (cfgModel.sqlDbType === keys_1.SqlDbType.postgres) {
109
+ const uniqueColumn = cfgModel.uniqueColumn; // id
110
+ if (!Array.isArray(uniqueColumn) || uniqueColumn.length === 0) {
111
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_ERROR_POSTGRES_UNIQUE_COLUMNS_NULL);
112
+ }
113
+ const unique_column = uniqueColumn
114
+ .map(s => {
115
+ return `"${s}"`;
116
+ })
117
+ .join(',');
118
+ return `insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) ON CONFLICT (${unique_column}) DO UPDATE set @@asUpdate:data `; // 关键字的前后,必须有空格
119
+ }
120
+ if (cfgModel.sqlDbType === keys_1.SqlDbType.sqlserver) {
121
+ const uniqueColumn = cfgModel.uniqueColumn; // id
122
+ if (uniqueColumn.length !== 1) {
123
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.CFG_UNIQUE_COLUMN_COUNT_MUST_ONE);
124
+ }
125
+ const uniqueColumnStr = uniqueColumn[0];
126
+ const uniqueColumnVal = '@@data.' + uniqueColumnStr;
127
+ const sql = '' + `IF EXISTS (SELECT 1 FROM @@table WHERE [${uniqueColumnStr}] = ${uniqueColumnVal})` + 'BEGIN\n' + ' UPDATE @@table\n' + ' SET @@asUpdate:data\n' + ` WHERE [${uniqueColumnStr}] = ${uniqueColumnVal} ;\n` + 'END\n' + 'ELSE\n' + 'BEGIN\n' + ' INSERT INTO @@table ( @@asInsertKeys:data )\n' + ' VALUES ( @@asInsertValues:data );\n' + 'END';
128
+ return sql;
129
+ }
130
+ return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) on duplicate key update @@asUpdate:data '; // 关键字的前后,必须有空格
131
+ }
132
+ /**
133
+ * 创建插入语句
134
+ * @param cfgModel
135
+ * @private
136
+ */
137
+ generateOriginSqlForInsert(cfgModel) {
138
+ if (cfgModel.sqlDbType === keys_1.SqlDbType.postgres) {
139
+ return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) RETURNING * ';
140
+ }
141
+ if (cfgModel.sqlDbType === keys_1.SqlDbType.sqlserver) {
142
+ return 'insert into @@table ( @@asInsertKeys:data ) OUTPUT INSERTED.* values( @@asInsertValues:data ) ';
143
+ }
144
+ return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )'; // 关键字的前后,必须有空格
145
+ }
146
+ async generateExecuteSql() {
147
+ const exeCtx = this.getExecuteContext();
148
+ const reqCfgModel = exeCtx.getCfgModel();
149
+ const sqlCfgList = reqCfgModel.sqlCfgList || [];
150
+ const { sqlTable, sqlSchema, sqlDatabase, sqlDbType, maxLimit, columns, columnsRelation } = reqCfgModel;
151
+ for (let i = 0; i < sqlCfgList.length; i++) {
152
+ const sqlCfgModel = sqlCfgList[i];
153
+ sqlCfgModel.sqlDbType = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlDbType, sqlDbType);
154
+ sqlCfgModel.sqlDatabase = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlDatabase, sqlDatabase);
155
+ sqlCfgModel.sqlSchema = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlSchema, sqlSchema);
156
+ sqlCfgModel.sqlTable = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.sqlTable, sqlTable);
157
+ sqlCfgModel.maxLimit = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.maxLimit, maxLimit);
158
+ sqlCfgModel.columns = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.columns, columns);
159
+ sqlCfgModel.columnsRelation = MixinUtils_1.MixinUtils.selectNotEmpty(sqlCfgModel.columnsRelation, columnsRelation);
160
+ await this.serviceHub.convertOriginToExecuteSql(sqlCfgModel);
161
+ exeCtx.getSqlCfgModels().push(sqlCfgModel);
162
+ }
163
+ }
164
+ }
165
+ exports.CrudProGenSqlService = CrudProGenSqlService;
@@ -1,32 +1,32 @@
1
- import { CrudProServiceBase } from './CrudProServiceBase';
2
- import { SqlCfgModel } from '../models/SqlCfgModel';
3
- declare class CrudProOriginToExecuteSql extends CrudProServiceBase {
4
- convertOriginToExecuteSql(sqlCfgModel: SqlCfgModel): Promise<void>;
5
- private generateWordMap;
6
- private generateWord;
7
- private generateDataAsInsertKeys;
8
- private generateTable;
9
- private generateColumns;
10
- /**
11
- * 生成查询条件
12
- * @param req
13
- * @param sqlCfg
14
- * @param conditionName
15
- * @private
16
- */
17
- private generateCondition;
18
- private generateOffsetLimit;
19
- private generateOrderBys;
20
- private generatePickResAs;
21
- private generateGetAttr;
22
- private generateDataUpdate;
23
- private generateDataAsInsertValues;
24
- private generateSqlJavaFunction;
25
- /**
26
- * 不会返回空。
27
- * @param sqlCfgModel
28
- * @private
29
- */
30
- private generateCfgColumns;
31
- }
32
- export { CrudProOriginToExecuteSql };
1
+ import { CrudProServiceBase } from './CrudProServiceBase';
2
+ import { SqlCfgModel } from '../models/SqlCfgModel';
3
+ declare class CrudProOriginToExecuteSql extends CrudProServiceBase {
4
+ convertOriginToExecuteSql(sqlCfgModel: SqlCfgModel): Promise<void>;
5
+ private generateWordMap;
6
+ private generateWord;
7
+ private generateDataAsInsertKeys;
8
+ private generateTable;
9
+ private generateColumns;
10
+ /**
11
+ * 生成查询条件
12
+ * @param req
13
+ * @param sqlCfg
14
+ * @param conditionName
15
+ * @private
16
+ */
17
+ private generateCondition;
18
+ private generateOffsetLimit;
19
+ private generateOrderBys;
20
+ private generatePickResAs;
21
+ private generateGetAttr;
22
+ private generateDataUpdate;
23
+ private generateDataAsInsertValues;
24
+ private generateSqlJavaFunction;
25
+ /**
26
+ * 不会返回空。
27
+ * @param sqlCfgModel
28
+ * @private
29
+ */
30
+ private generateCfgColumns;
31
+ }
32
+ export { CrudProOriginToExecuteSql };