midway-fatcms 0.0.1-beta.65 → 0.0.1-beta.66

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