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

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 (335) 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 +160 -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 +37 -37
  11. package/dist/controller/base/BaseApiController.js +164 -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 +129 -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 +144 -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 +31 -31
  27. package/dist/controller/gateway/PublicApiController.js +179 -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 +27 -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 +104 -104
  95. package/dist/libs/crud-pro/exceptions.js +117 -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 +334 -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 +21 -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/base64.d.ts +9 -9
  189. package/dist/libs/utils/base64.js +42 -42
  190. package/dist/libs/utils/common-dto.d.ts +18 -18
  191. package/dist/libs/utils/common-dto.js +40 -40
  192. package/dist/libs/utils/crypto-utils.d.ts +3 -3
  193. package/dist/libs/utils/crypto-utils.js +46 -46
  194. package/dist/libs/utils/errorToString.d.ts +2 -2
  195. package/dist/libs/utils/errorToString.js +57 -57
  196. package/dist/libs/utils/fatcms-request.d.ts +30 -30
  197. package/dist/libs/utils/fatcms-request.js +104 -104
  198. package/dist/libs/utils/functions.d.ts +5 -5
  199. package/dist/libs/utils/functions.js +72 -72
  200. package/dist/libs/utils/ordernum-utils.d.ts +2 -2
  201. package/dist/libs/utils/ordernum-utils.js +13 -13
  202. package/dist/libs/utils/parseConfig.d.ts +8 -8
  203. package/dist/libs/utils/parseConfig.js +47 -47
  204. package/dist/libs/utils/parseCreateSql.d.ts +10 -10
  205. package/dist/libs/utils/parseCreateSql.js +87 -87
  206. package/dist/libs/utils/render-utils.d.ts +28 -28
  207. package/dist/libs/utils/render-utils.js +133 -133
  208. package/dist/middleware/forbidden.middleware.d.ts +10 -10
  209. package/dist/middleware/forbidden.middleware.js +54 -54
  210. package/dist/middleware/global.middleware.d.ts +10 -10
  211. package/dist/middleware/global.middleware.js +266 -266
  212. package/dist/middleware/permission.middleware.d.ts +18 -18
  213. package/dist/middleware/permission.middleware.js +74 -74
  214. package/dist/middleware/rediscache.middleware.d.ts +3 -3
  215. package/dist/middleware/rediscache.middleware.js +77 -77
  216. package/dist/middleware/redislock.middleware.d.ts +7 -7
  217. package/dist/middleware/redislock.middleware.js +72 -72
  218. package/dist/middleware/tx.middleware.d.ts +9 -9
  219. package/dist/middleware/tx.middleware.js +40 -40
  220. package/dist/models/AsyncTaskModel.d.ts +74 -74
  221. package/dist/models/AsyncTaskModel.js +31 -31
  222. package/dist/models/RedisKeys.d.ts +15 -15
  223. package/dist/models/RedisKeys.js +18 -18
  224. package/dist/models/SystemEntities.d.ts +105 -105
  225. package/dist/models/SystemEntities.js +9 -9
  226. package/dist/models/SystemPerm.d.ts +95 -95
  227. package/dist/models/SystemPerm.js +100 -100
  228. package/dist/models/SystemTables.d.ts +25 -25
  229. package/dist/models/SystemTables.js +28 -28
  230. package/dist/models/bizmodels.d.ts +104 -104
  231. package/dist/models/bizmodels.js +39 -39
  232. package/dist/models/contextLogger.d.ts +25 -25
  233. package/dist/models/contextLogger.js +112 -112
  234. package/dist/models/devops.d.ts +12 -12
  235. package/dist/models/devops.js +19 -19
  236. package/dist/models/userSession.d.ts +62 -62
  237. package/dist/models/userSession.js +165 -165
  238. package/dist/schedule/anonymousContext.d.ts +14 -14
  239. package/dist/schedule/anonymousContext.js +59 -59
  240. package/dist/schedule/index.d.ts +4 -4
  241. package/dist/schedule/index.js +10 -10
  242. package/dist/schedule/runSchedule.d.ts +12 -12
  243. package/dist/schedule/runSchedule.js +68 -68
  244. package/dist/schedule/scheduleNames.d.ts +13 -13
  245. package/dist/schedule/scheduleNames.js +17 -17
  246. package/dist/service/AuthService.d.ts +71 -71
  247. package/dist/service/AuthService.js +263 -263
  248. package/dist/service/EnumInfoService.d.ts +30 -30
  249. package/dist/service/EnumInfoService.js +127 -127
  250. package/dist/service/FileCenterService.d.ts +43 -43
  251. package/dist/service/FileCenterService.js +351 -351
  252. package/dist/service/SysConfigService.d.ts +7 -7
  253. package/dist/service/SysConfigService.js +47 -47
  254. package/dist/service/UserAccountService.d.ts +23 -23
  255. package/dist/service/UserAccountService.js +107 -107
  256. package/dist/service/UserSessionService.d.ts +38 -38
  257. package/dist/service/UserSessionService.js +157 -157
  258. package/dist/service/VisitStatService.d.ts +14 -14
  259. package/dist/service/VisitStatService.js +158 -158
  260. package/dist/service/WorkbenchService.d.ts +53 -53
  261. package/dist/service/WorkbenchService.js +211 -211
  262. package/dist/service/anyapi/AnyApiSandboxService.d.ts +15 -15
  263. package/dist/service/anyapi/AnyApiSandboxService.js +110 -110
  264. package/dist/service/anyapi/AnyApiService.d.ts +27 -27
  265. package/dist/service/anyapi/AnyApiService.js +181 -181
  266. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -50
  267. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -287
  268. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -7
  269. package/dist/service/asyncTask/AsyncTaskService.js +34 -34
  270. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -10
  271. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -2
  272. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -7
  273. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -216
  274. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -36
  275. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +141 -141
  276. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -46
  277. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +135 -135
  278. package/dist/service/base/ApiBaseService.d.ts +15 -15
  279. package/dist/service/base/ApiBaseService.js +50 -50
  280. package/dist/service/base/ApiRateLimiter.d.ts +10 -10
  281. package/dist/service/base/ApiRateLimiter.js +51 -51
  282. package/dist/service/base/BaseService.d.ts +41 -41
  283. package/dist/service/base/BaseService.js +101 -101
  284. package/dist/service/base/RedisCacheService.d.ts +20 -20
  285. package/dist/service/base/RedisCacheService.js +57 -57
  286. package/dist/service/crudstd/CrudStdActionService.d.ts +17 -17
  287. package/dist/service/crudstd/CrudStdActionService.js +32 -32
  288. package/dist/service/crudstd/CrudStdConstant.d.ts +58 -58
  289. package/dist/service/crudstd/CrudStdConstant.js +64 -64
  290. package/dist/service/crudstd/CrudStdRelationService.d.ts +10 -10
  291. package/dist/service/crudstd/CrudStdRelationService.js +121 -121
  292. package/dist/service/crudstd/CrudStdService.d.ts +70 -70
  293. package/dist/service/crudstd/CrudStdService.js +403 -403
  294. package/dist/service/curd/CrudProQuick.d.ts +44 -44
  295. package/dist/service/curd/CrudProQuick.js +147 -147
  296. package/dist/service/curd/CurdMixByAccountService.d.ts +9 -9
  297. package/dist/service/curd/CurdMixByAccountService.js +113 -113
  298. package/dist/service/curd/CurdMixByDictService.d.ts +13 -13
  299. package/dist/service/curd/CurdMixByDictService.js +114 -114
  300. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +31 -31
  301. package/dist/service/curd/CurdMixByLinkToCustomService.js +203 -203
  302. package/dist/service/curd/CurdMixBySysConfigService.d.ts +9 -9
  303. package/dist/service/curd/CurdMixBySysConfigService.js +80 -80
  304. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +10 -10
  305. package/dist/service/curd/CurdMixByWorkbenchService.js +78 -78
  306. package/dist/service/curd/CurdMixService.d.ts +28 -28
  307. package/dist/service/curd/CurdMixService.js +100 -100
  308. package/dist/service/curd/CurdMixUtils.d.ts +57 -57
  309. package/dist/service/curd/CurdMixUtils.js +331 -331
  310. package/dist/service/curd/CurdProService.d.ts +32 -32
  311. package/dist/service/curd/CurdProService.js +212 -212
  312. package/dist/service/curd/fixCfgModel.d.ts +3 -3
  313. package/dist/service/curd/fixCfgModel.js +104 -104
  314. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +21 -21
  315. package/dist/service/proxyapi/ProxyApiLoadService.js +167 -167
  316. package/dist/service/proxyapi/ProxyApiService.d.ts +61 -61
  317. package/dist/service/proxyapi/ProxyApiService.js +294 -294
  318. package/dist/service/proxyapi/ProxyApiUtils.d.ts +15 -15
  319. package/dist/service/proxyapi/ProxyApiUtils.js +34 -34
  320. package/dist/service/proxyapi/RouteHandler.d.ts +5 -5
  321. package/dist/service/proxyapi/RouteHandler.js +9 -9
  322. package/dist/service/proxyapi/RouteTrie.d.ts +12 -12
  323. package/dist/service/proxyapi/RouteTrie.js +63 -63
  324. package/dist/service/proxyapi/WeightedRandom.d.ts +9 -9
  325. package/dist/service/proxyapi/WeightedRandom.js +31 -31
  326. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +8 -8
  327. package/dist/service/proxyapi/WeightedRoundRobin.js +32 -32
  328. package/index.d.ts +10 -10
  329. package/package.json +87 -87
  330. package/src/controller/manage/DocLibManageApi.ts +5 -5
  331. package/src/controller/manage/FileManageApi.ts +5 -5
  332. package/src/controller/manage/MenuManageApi.ts +4 -4
  333. package/src/service/proxyapi/WeightedRandom.ts +1 -1
  334. package/src/service/proxyapi/WeightedRoundRobin.ts +1 -1
  335. package/tsconfig.json +32 -32
@@ -1,355 +1,355 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CrudProGenSqlCondition = void 0;
4
- const SqlSegArg_1 = require("../models/SqlSegArg");
5
- const MixinUtils_1 = require("../utils/MixinUtils");
6
- const keys_1 = require("../models/keys");
7
- const exceptions_1 = require("../exceptions");
8
- const TypeUtils_1 = require("../utils/TypeUtils");
9
- const convertColumnName_1 = require("../utils/sqlConvert/convertColumnName");
10
- const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils_1.MixinUtils;
11
- const { isBasicType, isNumber } = TypeUtils_1.TypeUtils;
12
- const createFunc = (sqlCfg) => {
13
- return {
14
- toSqlColumnName: (columnName) => {
15
- return (0, convertColumnName_1.toSqlColumnName)(columnName, sqlCfg);
16
- },
17
- toMatchSqlColumnName: (columnName) => {
18
- const arr = columnName.split(',');
19
- return arr.map(s => (0, convertColumnName_1.toSqlColumnName)(s.trim(), sqlCfg)).join(',');
20
- },
21
- };
22
- };
23
- class ValueChecker {
24
- checkBasicArrayAndNotEmpty(value0, message) {
25
- // 不能为空
26
- if (!value0 || !Array.isArray(value0) || value0.length === 0) {
27
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.REQUEST_PARAM_ERROR, message);
28
- }
29
- // 元素必须是基本数据类型
30
- for (let i = 0; i < value0.length; i++) {
31
- const value0Element = value0[i];
32
- if (!TypeUtils_1.TypeUtils.isBasicType(value0Element)) {
33
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.REQUEST_PARAM_ERROR, message);
34
- }
35
- }
36
- }
37
- }
38
- function hasCompareKey(compare) {
39
- return keys_1.KeysOfConditions.COMPARE_KEYS.has(compare);
40
- }
41
- const valueChecker = new ValueChecker();
42
- class CrudProGenSqlCondition {
43
- constructor(sqlCfg) {
44
- this.sqlCfg = sqlCfg;
45
- }
46
- generateCondition(condition) {
47
- if (isEmpty(condition)) {
48
- return new SqlSegArg_1.SqlSegArg(' 1=1 ');
49
- }
50
- const sqlArgModel = this.generateByLogicalKey(condition);
51
- const sql = ' 1=1 and ' + sqlArgModel.sql;
52
- return new SqlSegArg_1.SqlSegArg(sql, sqlArgModel.args);
53
- }
54
- /**
55
- * condition = {$or:[{name:'zhangsan'},{name:'lisi'},{age: {$gt:18}}],sex:1}
56
- * where (name = 'zhangsan' or name = 'lisi' or age > 18) and sex = 1
57
- * @param condition
58
- * @private
59
- */
60
- generateByLogicalKey(condition) {
61
- if (isEmpty(condition)) {
62
- return null;
63
- }
64
- const { toSqlColumnName } = createFunc(this.sqlCfg);
65
- const tmpSqlList = [];
66
- const tmpArgList = [];
67
- const keys = Object.keys(condition);
68
- for (let i = 0; i < keys.length; i++) {
69
- const key = keys[i];
70
- const value = condition[key];
71
- if (!hasCompareKey(key)) {
72
- // 第一层的key,不能是比较运算符。
73
- // OR
74
- if (equalsIgnoreCase(keys_1.KeysOfConditions.$OR, key)) {
75
- TypeUtils_1.TypeUtils.assertJsonArray(value, exceptions_1.Exceptions.REQUEST_OR_PARAM_MUST_ARRAY);
76
- const a = this.generateByLogicalOR(value);
77
- if (a != null) {
78
- tmpSqlList.push(a.sql);
79
- if (isNotEmpty(a.args)) {
80
- tmpArgList.push(...a.args);
81
- }
82
- }
83
- }
84
- // AND
85
- else if (TypeUtils_1.TypeUtils.isBasicType(value)) {
86
- tmpSqlList.push(toSqlColumnName(key) + '= ?');
87
- tmpArgList.push(value);
88
- }
89
- else {
90
- // AND
91
- const a = this.generateByCompareKey(key, value);
92
- if (a != null) {
93
- tmpSqlList.push(a.sql);
94
- if (MixinUtils_1.MixinUtils.isNotEmpty(a.args)) {
95
- tmpArgList.push(...a.args);
96
- }
97
- }
98
- }
99
- }
100
- }
101
- if (isEmpty(tmpSqlList)) {
102
- return null;
103
- }
104
- // const sql = "(" + StringUtils.join(tmpSqlList, " AND ") + ")";
105
- const sql = '(' + tmpSqlList.join(' AND ') + ')';
106
- return new SqlSegArg_1.SqlSegArg(sql, tmpArgList);
107
- }
108
- generateByLogicalOR(jsonArray) {
109
- if (MixinUtils_1.MixinUtils.isEmpty(jsonArray)) {
110
- return null;
111
- }
112
- const tmpSqlList = [];
113
- const tmpArgList = [];
114
- for (let i = 0; i < jsonArray.length; i++) {
115
- const jsonObject = jsonArray[i];
116
- const a = this.generateByLogicalKey(jsonObject);
117
- if (a != null) {
118
- tmpSqlList.push(a.sql);
119
- if (MixinUtils_1.MixinUtils.isNotEmpty(a.args)) {
120
- tmpArgList.push(...a.args);
121
- }
122
- }
123
- }
124
- const sql = '(' + tmpSqlList.join(' OR ') + ')';
125
- return new SqlSegArg_1.SqlSegArg(sql, tmpArgList);
126
- }
127
- // 例如:
128
- // {name:1, age:{"$gt":5, "$lt":10}, } ==> name = 1 and (age > 5 and age < 10)
129
- // {name:1, age:{"$nin":[1,2,3],"$lt":10} } ==> name = 1 and (age not in (1,2,3) and age < 10)
130
- // 比较运算符
131
- generateByCompareKey(key, map) {
132
- if (isEmpty(map)) {
133
- return null;
134
- }
135
- const { toSqlColumnName, toMatchSqlColumnName } = createFunc(this.sqlCfg);
136
- this.generateByCompareKeyCheckParam(key, map);
137
- const tmpSqlList = [];
138
- const tmpArgList = [];
139
- let hasNoArgSql = false;
140
- const compareSet = Object.keys(map);
141
- for (let i = 0; i < compareSet.length; i++) {
142
- const compare = compareSet[i];
143
- if (hasCompareKey(compare)) {
144
- const value0 = map[compare];
145
- let tmpSql = '';
146
- if (equalsIgnoreCase(keys_1.KeysOfConditions.$NULL, compare)) {
147
- tmpSql = `${toSqlColumnName(key)} is null `;
148
- hasNoArgSql = true;
149
- }
150
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_NULL, compare)) {
151
- tmpSql = `${toSqlColumnName(key)} is not null `;
152
- hasNoArgSql = true;
153
- }
154
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$GT, compare)) {
155
- tmpArgList.push(value0);
156
- tmpSql = `${toSqlColumnName(key)} > ?`;
157
- }
158
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$GTE, compare)) {
159
- tmpArgList.push(value0);
160
- tmpSql = `${toSqlColumnName(key)} >= ?`;
161
- }
162
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LT, compare)) {
163
- tmpArgList.push(value0);
164
- tmpSql = `${toSqlColumnName(key)} < ?`;
165
- }
166
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LTE, compare)) {
167
- tmpArgList.push(value0);
168
- tmpSql = `${toSqlColumnName(key)} <= ?`;
169
- }
170
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NE, compare)) {
171
- tmpArgList.push(value0);
172
- tmpSql = `${toSqlColumnName(key)} != ?`;
173
- }
174
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$IN, compare)) {
175
- const array = [...value0];
176
- if (isNotEmpty(array)) {
177
- const pm = array.map(() => '?').join(',');
178
- tmpSql = `${toSqlColumnName(key)} in (${pm})`;
179
- tmpArgList.push(...array);
180
- }
181
- }
182
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NIN, compare)) {
183
- const array = [...value0];
184
- if (isNotEmpty(array)) {
185
- const pm = array.map(() => '?').join(',');
186
- tmpSql = `${toSqlColumnName(key)} not in (${pm})`;
187
- tmpArgList.push(...array);
188
- }
189
- }
190
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE, compare)) {
191
- tmpArgList.push(value0);
192
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat(?, '%')`; // like前缀匹配
193
- if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
194
- tmpSql = `${toSqlColumnName(key)} like concat(?::text, '%')`; // like前缀匹配
195
- }
196
- }
197
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE, compare)) {
198
- tmpArgList.push(value0);
199
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat(?, '%')`;
200
- if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
201
- tmpSql = `${toSqlColumnName(key)} not like concat(?::text, '%')`;
202
- }
203
- }
204
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE_INCLUDE, compare)) {
205
- tmpArgList.push(value0);
206
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat('%', ?, '%')`; // like包含
207
- if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
208
- tmpSql = `${toSqlColumnName(key)} like concat('%', ?::text, '%')`; // like包含
209
- }
210
- }
211
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$JSON_ARRAY_CONTAINS, compare)) {
212
- if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.mysql) {
213
- tmpArgList.push(value0);
214
- tmpSql = `JSON_CONTAINS( ${toSqlColumnName(key)} , JSON_ARRAY(?), '$')`; // MYSQL JSON_CONTAINS包含
215
- }
216
- if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
217
- tmpArgList.push(value0);
218
- tmpSql = `${toSqlColumnName(key)} @> ('["' || ? || '"]')::jsonb`; // POSTGRES JSON_CONTAINS包含
219
- }
220
- }
221
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
222
- tmpArgList.push(value0);
223
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat('%',?, '%')`; // like不包含
224
- if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
225
- tmpSql = `${toSqlColumnName(key)} not like concat('%',?::text, '%')`; // like不包含
226
- }
227
- }
228
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH, compare)) {
229
- tmpArgList.push(value0);
230
- tmpSql = `match(${toMatchSqlColumnName(key)}) against(?)`;
231
- }
232
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH_BOOL, compare)) {
233
- tmpArgList.push(value0);
234
- tmpSql = `match(${toMatchSqlColumnName(key)}) against( ? in boolean mode)`;
235
- }
236
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$RANGE, compare)) {
237
- const array = [...value0];
238
- if (isNotEmpty(array) && array.length === 2) {
239
- tmpSql = `(${toSqlColumnName(key)} between ? and ? )`;
240
- tmpArgList.push(...array);
241
- }
242
- }
243
- tmpSqlList.push(tmpSql);
244
- }
245
- }
246
- if (isEmpty(tmpArgList) && !hasNoArgSql) {
247
- return null;
248
- }
249
- const sql = '( ' + tmpSqlList.join(' and ') + ' )';
250
- return new SqlSegArg_1.SqlSegArg(sql, tmpArgList);
251
- }
252
- /**
253
- * 参数校验
254
- * @param key
255
- * @param map
256
- * @private
257
- */
258
- generateByCompareKeyCheckParam(key, map) {
259
- if (isEmpty(map)) {
260
- return null;
261
- }
262
- const compareSet = Object.keys(map);
263
- const throwCommonException = (name, type) => {
264
- throw new exceptions_1.CommonException(exceptions_1.Exceptions.REQUEST_PARAM_ERROR, `${name}参数必须是${type}`);
265
- };
266
- for (let i = 0; i < compareSet.length; i++) {
267
- const compare = compareSet[i];
268
- if (hasCompareKey(compare)) {
269
- const value0 = map[compare];
270
- if (equalsIgnoreCase(keys_1.KeysOfConditions.$GT, compare)) {
271
- if (!isBasicType(value0)) {
272
- throwCommonException(keys_1.KeysOfConditions.$GT, '字符串、数字');
273
- }
274
- }
275
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$GTE, compare)) {
276
- if (!isBasicType(value0)) {
277
- throwCommonException(keys_1.KeysOfConditions.$GTE, '字符串、数字');
278
- }
279
- }
280
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LT, compare)) {
281
- if (!isBasicType(value0)) {
282
- throwCommonException(keys_1.KeysOfConditions.$LT, '字符串、数字');
283
- }
284
- }
285
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LTE, compare)) {
286
- if (!isBasicType(value0)) {
287
- throwCommonException(keys_1.KeysOfConditions.$LTE, '字符串、数字');
288
- }
289
- }
290
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NE, compare)) {
291
- if (!isBasicType(value0)) {
292
- throwCommonException(keys_1.KeysOfConditions.$NE, '字符串、数字');
293
- }
294
- }
295
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$IN, compare)) {
296
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
297
- }
298
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NIN, compare)) {
299
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
300
- }
301
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE, compare)) {
302
- if (!isBasicType(value0)) {
303
- throwCommonException(keys_1.KeysOfConditions.$LIKE, '字符串');
304
- }
305
- }
306
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE, compare)) {
307
- if (!isBasicType(value0)) {
308
- throwCommonException(keys_1.KeysOfConditions.$NOT_LIKE, '字符串');
309
- }
310
- }
311
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE_INCLUDE, compare)) {
312
- if (!isBasicType(value0)) {
313
- throwCommonException(keys_1.KeysOfConditions.$LIKE_INCLUDE, '字符串');
314
- }
315
- }
316
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
317
- if (!isBasicType(value0)) {
318
- throwCommonException(keys_1.KeysOfConditions.$NOT_LIKE_INCLUDE, '字符串');
319
- }
320
- }
321
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$JSON_ARRAY_CONTAINS, compare)) {
322
- if (!isBasicType(value0)) {
323
- throwCommonException(keys_1.KeysOfConditions.$JSON_ARRAY_CONTAINS, '字符串或数字');
324
- }
325
- }
326
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH, compare)) {
327
- if (!isBasicType(value0)) {
328
- throwCommonException(keys_1.KeysOfConditions.$MATCH, '字符串');
329
- }
330
- }
331
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH_BOOL, compare)) {
332
- if (!isBasicType(value0)) {
333
- throwCommonException(keys_1.KeysOfConditions.$MATCH_BOOL, '字符串');
334
- }
335
- }
336
- else if (equalsIgnoreCase(keys_1.KeysOfConditions.$RANGE, compare)) {
337
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是两个数字组成的数组`);
338
- const array = [...value0];
339
- if (isNotEmpty(array) && array.length === 2) {
340
- for (let j = 0; j < array.length; j++) {
341
- const arrayElement = array[j];
342
- if (!isNumber(arrayElement)) {
343
- throwCommonException(keys_1.KeysOfConditions.$RANGE, '数组(两个数字)');
344
- }
345
- }
346
- }
347
- else {
348
- throwCommonException(keys_1.KeysOfConditions.$RANGE, '数组(两个数字)');
349
- }
350
- }
351
- }
352
- }
353
- }
354
- }
355
- exports.CrudProGenSqlCondition = CrudProGenSqlCondition;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CrudProGenSqlCondition = void 0;
4
+ const SqlSegArg_1 = require("../models/SqlSegArg");
5
+ const MixinUtils_1 = require("../utils/MixinUtils");
6
+ const keys_1 = require("../models/keys");
7
+ const exceptions_1 = require("../exceptions");
8
+ const TypeUtils_1 = require("../utils/TypeUtils");
9
+ const convertColumnName_1 = require("../utils/sqlConvert/convertColumnName");
10
+ const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils_1.MixinUtils;
11
+ const { isBasicType, isNumber } = TypeUtils_1.TypeUtils;
12
+ const createFunc = (sqlCfg) => {
13
+ return {
14
+ toSqlColumnName: (columnName) => {
15
+ return (0, convertColumnName_1.toSqlColumnName)(columnName, sqlCfg);
16
+ },
17
+ toMatchSqlColumnName: (columnName) => {
18
+ const arr = columnName.split(',');
19
+ return arr.map(s => (0, convertColumnName_1.toSqlColumnName)(s.trim(), sqlCfg)).join(',');
20
+ },
21
+ };
22
+ };
23
+ class ValueChecker {
24
+ checkBasicArrayAndNotEmpty(value0, message) {
25
+ // 不能为空
26
+ if (!value0 || !Array.isArray(value0) || value0.length === 0) {
27
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.REQUEST_PARAM_ERROR, message);
28
+ }
29
+ // 元素必须是基本数据类型
30
+ for (let i = 0; i < value0.length; i++) {
31
+ const value0Element = value0[i];
32
+ if (!TypeUtils_1.TypeUtils.isBasicType(value0Element)) {
33
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.REQUEST_PARAM_ERROR, message);
34
+ }
35
+ }
36
+ }
37
+ }
38
+ function hasCompareKey(compare) {
39
+ return keys_1.KeysOfConditions.COMPARE_KEYS.has(compare);
40
+ }
41
+ const valueChecker = new ValueChecker();
42
+ class CrudProGenSqlCondition {
43
+ constructor(sqlCfg) {
44
+ this.sqlCfg = sqlCfg;
45
+ }
46
+ generateCondition(condition) {
47
+ if (isEmpty(condition)) {
48
+ return new SqlSegArg_1.SqlSegArg(' 1=1 ');
49
+ }
50
+ const sqlArgModel = this.generateByLogicalKey(condition);
51
+ const sql = ' 1=1 and ' + sqlArgModel.sql;
52
+ return new SqlSegArg_1.SqlSegArg(sql, sqlArgModel.args);
53
+ }
54
+ /**
55
+ * condition = {$or:[{name:'zhangsan'},{name:'lisi'},{age: {$gt:18}}],sex:1}
56
+ * where (name = 'zhangsan' or name = 'lisi' or age > 18) and sex = 1
57
+ * @param condition
58
+ * @private
59
+ */
60
+ generateByLogicalKey(condition) {
61
+ if (isEmpty(condition)) {
62
+ return null;
63
+ }
64
+ const { toSqlColumnName } = createFunc(this.sqlCfg);
65
+ const tmpSqlList = [];
66
+ const tmpArgList = [];
67
+ const keys = Object.keys(condition);
68
+ for (let i = 0; i < keys.length; i++) {
69
+ const key = keys[i];
70
+ const value = condition[key];
71
+ if (!hasCompareKey(key)) {
72
+ // 第一层的key,不能是比较运算符。
73
+ // OR
74
+ if (equalsIgnoreCase(keys_1.KeysOfConditions.$OR, key)) {
75
+ TypeUtils_1.TypeUtils.assertJsonArray(value, exceptions_1.Exceptions.REQUEST_OR_PARAM_MUST_ARRAY);
76
+ const a = this.generateByLogicalOR(value);
77
+ if (a != null) {
78
+ tmpSqlList.push(a.sql);
79
+ if (isNotEmpty(a.args)) {
80
+ tmpArgList.push(...a.args);
81
+ }
82
+ }
83
+ }
84
+ // AND
85
+ else if (TypeUtils_1.TypeUtils.isBasicType(value)) {
86
+ tmpSqlList.push(toSqlColumnName(key) + '= ?');
87
+ tmpArgList.push(value);
88
+ }
89
+ else {
90
+ // AND
91
+ const a = this.generateByCompareKey(key, value);
92
+ if (a != null) {
93
+ tmpSqlList.push(a.sql);
94
+ if (MixinUtils_1.MixinUtils.isNotEmpty(a.args)) {
95
+ tmpArgList.push(...a.args);
96
+ }
97
+ }
98
+ }
99
+ }
100
+ }
101
+ if (isEmpty(tmpSqlList)) {
102
+ return null;
103
+ }
104
+ // const sql = "(" + StringUtils.join(tmpSqlList, " AND ") + ")";
105
+ const sql = '(' + tmpSqlList.join(' AND ') + ')';
106
+ return new SqlSegArg_1.SqlSegArg(sql, tmpArgList);
107
+ }
108
+ generateByLogicalOR(jsonArray) {
109
+ if (MixinUtils_1.MixinUtils.isEmpty(jsonArray)) {
110
+ return null;
111
+ }
112
+ const tmpSqlList = [];
113
+ const tmpArgList = [];
114
+ for (let i = 0; i < jsonArray.length; i++) {
115
+ const jsonObject = jsonArray[i];
116
+ const a = this.generateByLogicalKey(jsonObject);
117
+ if (a != null) {
118
+ tmpSqlList.push(a.sql);
119
+ if (MixinUtils_1.MixinUtils.isNotEmpty(a.args)) {
120
+ tmpArgList.push(...a.args);
121
+ }
122
+ }
123
+ }
124
+ const sql = '(' + tmpSqlList.join(' OR ') + ')';
125
+ return new SqlSegArg_1.SqlSegArg(sql, tmpArgList);
126
+ }
127
+ // 例如:
128
+ // {name:1, age:{"$gt":5, "$lt":10}, } ==> name = 1 and (age > 5 and age < 10)
129
+ // {name:1, age:{"$nin":[1,2,3],"$lt":10} } ==> name = 1 and (age not in (1,2,3) and age < 10)
130
+ // 比较运算符
131
+ generateByCompareKey(key, map) {
132
+ if (isEmpty(map)) {
133
+ return null;
134
+ }
135
+ const { toSqlColumnName, toMatchSqlColumnName } = createFunc(this.sqlCfg);
136
+ this.generateByCompareKeyCheckParam(key, map);
137
+ const tmpSqlList = [];
138
+ const tmpArgList = [];
139
+ let hasNoArgSql = false;
140
+ const compareSet = Object.keys(map);
141
+ for (let i = 0; i < compareSet.length; i++) {
142
+ const compare = compareSet[i];
143
+ if (hasCompareKey(compare)) {
144
+ const value0 = map[compare];
145
+ let tmpSql = '';
146
+ if (equalsIgnoreCase(keys_1.KeysOfConditions.$NULL, compare)) {
147
+ tmpSql = `${toSqlColumnName(key)} is null `;
148
+ hasNoArgSql = true;
149
+ }
150
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_NULL, compare)) {
151
+ tmpSql = `${toSqlColumnName(key)} is not null `;
152
+ hasNoArgSql = true;
153
+ }
154
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$GT, compare)) {
155
+ tmpArgList.push(value0);
156
+ tmpSql = `${toSqlColumnName(key)} > ?`;
157
+ }
158
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$GTE, compare)) {
159
+ tmpArgList.push(value0);
160
+ tmpSql = `${toSqlColumnName(key)} >= ?`;
161
+ }
162
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LT, compare)) {
163
+ tmpArgList.push(value0);
164
+ tmpSql = `${toSqlColumnName(key)} < ?`;
165
+ }
166
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LTE, compare)) {
167
+ tmpArgList.push(value0);
168
+ tmpSql = `${toSqlColumnName(key)} <= ?`;
169
+ }
170
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NE, compare)) {
171
+ tmpArgList.push(value0);
172
+ tmpSql = `${toSqlColumnName(key)} != ?`;
173
+ }
174
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$IN, compare)) {
175
+ const array = [...value0];
176
+ if (isNotEmpty(array)) {
177
+ const pm = array.map(() => '?').join(',');
178
+ tmpSql = `${toSqlColumnName(key)} in (${pm})`;
179
+ tmpArgList.push(...array);
180
+ }
181
+ }
182
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NIN, compare)) {
183
+ const array = [...value0];
184
+ if (isNotEmpty(array)) {
185
+ const pm = array.map(() => '?').join(',');
186
+ tmpSql = `${toSqlColumnName(key)} not in (${pm})`;
187
+ tmpArgList.push(...array);
188
+ }
189
+ }
190
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE, compare)) {
191
+ tmpArgList.push(value0);
192
+ tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat(?, '%')`; // like前缀匹配
193
+ if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
194
+ tmpSql = `${toSqlColumnName(key)} like concat(?::text, '%')`; // like前缀匹配
195
+ }
196
+ }
197
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE, compare)) {
198
+ tmpArgList.push(value0);
199
+ tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat(?, '%')`;
200
+ if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
201
+ tmpSql = `${toSqlColumnName(key)} not like concat(?::text, '%')`;
202
+ }
203
+ }
204
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE_INCLUDE, compare)) {
205
+ tmpArgList.push(value0);
206
+ tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat('%', ?, '%')`; // like包含
207
+ if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
208
+ tmpSql = `${toSqlColumnName(key)} like concat('%', ?::text, '%')`; // like包含
209
+ }
210
+ }
211
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$JSON_ARRAY_CONTAINS, compare)) {
212
+ if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.mysql) {
213
+ tmpArgList.push(value0);
214
+ tmpSql = `JSON_CONTAINS( ${toSqlColumnName(key)} , JSON_ARRAY(?), '$')`; // MYSQL JSON_CONTAINS包含
215
+ }
216
+ if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
217
+ tmpArgList.push(value0);
218
+ tmpSql = `${toSqlColumnName(key)} @> ('["' || ? || '"]')::jsonb`; // POSTGRES JSON_CONTAINS包含
219
+ }
220
+ }
221
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
222
+ tmpArgList.push(value0);
223
+ tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat('%',?, '%')`; // like不包含
224
+ if (this.sqlCfg.sqlDbType === keys_1.SqlDbType.postgres) {
225
+ tmpSql = `${toSqlColumnName(key)} not like concat('%',?::text, '%')`; // like不包含
226
+ }
227
+ }
228
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH, compare)) {
229
+ tmpArgList.push(value0);
230
+ tmpSql = `match(${toMatchSqlColumnName(key)}) against(?)`;
231
+ }
232
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH_BOOL, compare)) {
233
+ tmpArgList.push(value0);
234
+ tmpSql = `match(${toMatchSqlColumnName(key)}) against( ? in boolean mode)`;
235
+ }
236
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$RANGE, compare)) {
237
+ const array = [...value0];
238
+ if (isNotEmpty(array) && array.length === 2) {
239
+ tmpSql = `(${toSqlColumnName(key)} between ? and ? )`;
240
+ tmpArgList.push(...array);
241
+ }
242
+ }
243
+ tmpSqlList.push(tmpSql);
244
+ }
245
+ }
246
+ if (isEmpty(tmpArgList) && !hasNoArgSql) {
247
+ return null;
248
+ }
249
+ const sql = '( ' + tmpSqlList.join(' and ') + ' )';
250
+ return new SqlSegArg_1.SqlSegArg(sql, tmpArgList);
251
+ }
252
+ /**
253
+ * 参数校验
254
+ * @param key
255
+ * @param map
256
+ * @private
257
+ */
258
+ generateByCompareKeyCheckParam(key, map) {
259
+ if (isEmpty(map)) {
260
+ return null;
261
+ }
262
+ const compareSet = Object.keys(map);
263
+ const throwCommonException = (name, type) => {
264
+ throw new exceptions_1.CommonException(exceptions_1.Exceptions.REQUEST_PARAM_ERROR, `${name}参数必须是${type}`);
265
+ };
266
+ for (let i = 0; i < compareSet.length; i++) {
267
+ const compare = compareSet[i];
268
+ if (hasCompareKey(compare)) {
269
+ const value0 = map[compare];
270
+ if (equalsIgnoreCase(keys_1.KeysOfConditions.$GT, compare)) {
271
+ if (!isBasicType(value0)) {
272
+ throwCommonException(keys_1.KeysOfConditions.$GT, '字符串、数字');
273
+ }
274
+ }
275
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$GTE, compare)) {
276
+ if (!isBasicType(value0)) {
277
+ throwCommonException(keys_1.KeysOfConditions.$GTE, '字符串、数字');
278
+ }
279
+ }
280
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LT, compare)) {
281
+ if (!isBasicType(value0)) {
282
+ throwCommonException(keys_1.KeysOfConditions.$LT, '字符串、数字');
283
+ }
284
+ }
285
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LTE, compare)) {
286
+ if (!isBasicType(value0)) {
287
+ throwCommonException(keys_1.KeysOfConditions.$LTE, '字符串、数字');
288
+ }
289
+ }
290
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NE, compare)) {
291
+ if (!isBasicType(value0)) {
292
+ throwCommonException(keys_1.KeysOfConditions.$NE, '字符串、数字');
293
+ }
294
+ }
295
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$IN, compare)) {
296
+ valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
297
+ }
298
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NIN, compare)) {
299
+ valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
300
+ }
301
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE, compare)) {
302
+ if (!isBasicType(value0)) {
303
+ throwCommonException(keys_1.KeysOfConditions.$LIKE, '字符串');
304
+ }
305
+ }
306
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE, compare)) {
307
+ if (!isBasicType(value0)) {
308
+ throwCommonException(keys_1.KeysOfConditions.$NOT_LIKE, '字符串');
309
+ }
310
+ }
311
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$LIKE_INCLUDE, compare)) {
312
+ if (!isBasicType(value0)) {
313
+ throwCommonException(keys_1.KeysOfConditions.$LIKE_INCLUDE, '字符串');
314
+ }
315
+ }
316
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
317
+ if (!isBasicType(value0)) {
318
+ throwCommonException(keys_1.KeysOfConditions.$NOT_LIKE_INCLUDE, '字符串');
319
+ }
320
+ }
321
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$JSON_ARRAY_CONTAINS, compare)) {
322
+ if (!isBasicType(value0)) {
323
+ throwCommonException(keys_1.KeysOfConditions.$JSON_ARRAY_CONTAINS, '字符串或数字');
324
+ }
325
+ }
326
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH, compare)) {
327
+ if (!isBasicType(value0)) {
328
+ throwCommonException(keys_1.KeysOfConditions.$MATCH, '字符串');
329
+ }
330
+ }
331
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$MATCH_BOOL, compare)) {
332
+ if (!isBasicType(value0)) {
333
+ throwCommonException(keys_1.KeysOfConditions.$MATCH_BOOL, '字符串');
334
+ }
335
+ }
336
+ else if (equalsIgnoreCase(keys_1.KeysOfConditions.$RANGE, compare)) {
337
+ valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是两个数字组成的数组`);
338
+ const array = [...value0];
339
+ if (isNotEmpty(array) && array.length === 2) {
340
+ for (let j = 0; j < array.length; j++) {
341
+ const arrayElement = array[j];
342
+ if (!isNumber(arrayElement)) {
343
+ throwCommonException(keys_1.KeysOfConditions.$RANGE, '数组(两个数字)');
344
+ }
345
+ }
346
+ }
347
+ else {
348
+ throwCommonException(keys_1.KeysOfConditions.$RANGE, '数组(两个数字)');
349
+ }
350
+ }
351
+ }
352
+ }
353
+ }
354
+ }
355
+ exports.CrudProGenSqlCondition = CrudProGenSqlCondition;