midway-fatcms 0.0.1-beta.3 → 0.0.1-beta.30

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 (453) hide show
  1. package/.eslintrc.json +14 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +7 -0
  4. package/package.json +25 -24
  5. package/tsconfig.json +32 -0
  6. package/dist/config/config.default.d.ts +0 -3
  7. package/dist/config/config.default.js +0 -148
  8. package/dist/config/seed/aeskey.txt +0 -1
  9. package/dist/config/utils.d.ts +0 -1
  10. package/dist/config/utils.js +0 -23
  11. package/dist/configuration.d.ts +0 -6
  12. package/dist/configuration.js +0 -89
  13. package/dist/controller/base/BaseApiController.d.ts +0 -31
  14. package/dist/controller/base/BaseApiController.js +0 -138
  15. package/dist/controller/gateway/AnyApiGatewayController.d.ts +0 -13
  16. package/dist/controller/gateway/AnyApiGatewayController.js +0 -55
  17. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +0 -21
  18. package/dist/controller/gateway/CrudMtdGatewayController.js +0 -116
  19. package/dist/controller/gateway/CrudStdGatewayController.d.ts +0 -38
  20. package/dist/controller/gateway/CrudStdGatewayController.js +0 -137
  21. package/dist/controller/gateway/DocGatewayController.d.ts +0 -27
  22. package/dist/controller/gateway/DocGatewayController.js +0 -174
  23. package/dist/controller/gateway/FileController.d.ts +0 -25
  24. package/dist/controller/gateway/FileController.js +0 -129
  25. package/dist/controller/gateway/ProxyApiGatewayController.d.ts +0 -18
  26. package/dist/controller/gateway/ProxyApiGatewayController.js +0 -78
  27. package/dist/controller/gateway/PublicApiController.d.ts +0 -27
  28. package/dist/controller/gateway/PublicApiController.js +0 -167
  29. package/dist/controller/gateway/StaticController.d.ts +0 -21
  30. package/dist/controller/gateway/StaticController.js +0 -265
  31. package/dist/controller/helpers.controller.d.ts +0 -39
  32. package/dist/controller/helpers.controller.js +0 -188
  33. package/dist/controller/home.controller.d.ts +0 -9
  34. package/dist/controller/home.controller.js +0 -71
  35. package/dist/controller/manage/AnyApiMangeApi.d.ts +0 -10
  36. package/dist/controller/manage/AnyApiMangeApi.js +0 -98
  37. package/dist/controller/manage/AppLogMangeApi.d.ts +0 -10
  38. package/dist/controller/manage/AppLogMangeApi.js +0 -88
  39. package/dist/controller/manage/AppMangeApi.d.ts +0 -10
  40. package/dist/controller/manage/AppMangeApi.js +0 -88
  41. package/dist/controller/manage/AppPageMangeApi.d.ts +0 -10
  42. package/dist/controller/manage/AppPageMangeApi.js +0 -87
  43. package/dist/controller/manage/AppSchemaHistoryApi.d.ts +0 -10
  44. package/dist/controller/manage/AppSchemaHistoryApi.js +0 -83
  45. package/dist/controller/manage/CrudMethodsMangeApi.d.ts +0 -10
  46. package/dist/controller/manage/CrudMethodsMangeApi.js +0 -84
  47. package/dist/controller/manage/CrudStandardDesignApi.d.ts +0 -38
  48. package/dist/controller/manage/CrudStandardDesignApi.js +0 -339
  49. package/dist/controller/manage/DataDictManageApi.d.ts +0 -15
  50. package/dist/controller/manage/DataDictManageApi.js +0 -133
  51. package/dist/controller/manage/DeployManageApi.d.ts +0 -19
  52. package/dist/controller/manage/DeployManageApi.js +0 -176
  53. package/dist/controller/manage/DocLibManageApi.d.ts +0 -10
  54. package/dist/controller/manage/DocLibManageApi.js +0 -104
  55. package/dist/controller/manage/DocManageApi.d.ts +0 -11
  56. package/dist/controller/manage/DocManageApi.js +0 -130
  57. package/dist/controller/manage/FileManageApi.d.ts +0 -13
  58. package/dist/controller/manage/FileManageApi.js +0 -77
  59. package/dist/controller/manage/LowCodeTplManageApi.d.ts +0 -13
  60. package/dist/controller/manage/LowCodeTplManageApi.js +0 -86
  61. package/dist/controller/manage/MenuManageApi.d.ts +0 -10
  62. package/dist/controller/manage/MenuManageApi.js +0 -93
  63. package/dist/controller/manage/ProxyApiMangeApi.d.ts +0 -10
  64. package/dist/controller/manage/ProxyApiMangeApi.js +0 -87
  65. package/dist/controller/manage/SuperAdminManageApi.d.ts +0 -24
  66. package/dist/controller/manage/SuperAdminManageApi.js +0 -149
  67. package/dist/controller/manage/SysConfigMangeApi.d.ts +0 -11
  68. package/dist/controller/manage/SysConfigMangeApi.js +0 -124
  69. package/dist/controller/manage/SystemInfoManageApi.d.ts +0 -12
  70. package/dist/controller/manage/SystemInfoManageApi.js +0 -66
  71. package/dist/controller/manage/UserAccountManageApi.d.ts +0 -14
  72. package/dist/controller/manage/UserAccountManageApi.js +0 -124
  73. package/dist/controller/manage/WorkbenchMangeApi.d.ts +0 -11
  74. package/dist/controller/manage/WorkbenchMangeApi.js +0 -103
  75. package/dist/controller/medstatistic/MedAdminController.d.ts +0 -35
  76. package/dist/controller/medstatistic/MedAdminController.js +0 -205
  77. package/dist/controller/medstatistic/MedClientController.d.ts +0 -28
  78. package/dist/controller/medstatistic/MedClientController.js +0 -188
  79. package/dist/controller/medstatistic/MedMessageService.d.ts +0 -19
  80. package/dist/controller/medstatistic/MedMessageService.js +0 -95
  81. package/dist/controller/medstatistic/MedScoreService.d.ts +0 -21
  82. package/dist/controller/medstatistic/MedScoreService.js +0 -107
  83. package/dist/controller/medstatistic/constants.d.ts +0 -32
  84. package/dist/controller/medstatistic/constants.js +0 -43
  85. package/dist/controller/myinfo/AuthController.d.ts +0 -37
  86. package/dist/controller/myinfo/AuthController.js +0 -189
  87. package/dist/controller/myinfo/MyInfoController.d.ts +0 -13
  88. package/dist/controller/myinfo/MyInfoController.js +0 -51
  89. package/dist/controller/render/AppRenderController.d.ts +0 -11
  90. package/dist/controller/render/AppRenderController.js +0 -85
  91. package/dist/controller/test.controller.d.ts +0 -8
  92. package/dist/controller/test.controller.js +0 -51
  93. package/dist/filter/default.filter.d.ts +0 -7
  94. package/dist/filter/default.filter.js +0 -23
  95. package/dist/filter/notfound.filter.d.ts +0 -5
  96. package/dist/filter/notfound.filter.js +0 -20
  97. package/dist/index.d.ts +0 -71
  98. package/dist/index.js +0 -89
  99. package/dist/interface.d.ts +0 -27
  100. package/dist/interface.js +0 -3
  101. package/dist/libs/crud-pro/CrudPro.d.ts +0 -36
  102. package/dist/libs/crud-pro/CrudPro.js +0 -131
  103. package/dist/libs/crud-pro/defaultConfigs.d.ts +0 -4
  104. package/dist/libs/crud-pro/defaultConfigs.js +0 -13
  105. package/dist/libs/crud-pro/exceptions.d.ts +0 -104
  106. package/dist/libs/crud-pro/exceptions.js +0 -117
  107. package/dist/libs/crud-pro/interfaces.d.ts +0 -157
  108. package/dist/libs/crud-pro/interfaces.js +0 -12
  109. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +0 -42
  110. package/dist/libs/crud-pro/models/ExecuteContext.js +0 -79
  111. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +0 -31
  112. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +0 -64
  113. package/dist/libs/crud-pro/models/FuncContext.d.ts +0 -18
  114. package/dist/libs/crud-pro/models/FuncContext.js +0 -6
  115. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +0 -65
  116. package/dist/libs/crud-pro/models/RequestCfgModel.js +0 -81
  117. package/dist/libs/crud-pro/models/RequestModel.d.ts +0 -25
  118. package/dist/libs/crud-pro/models/RequestModel.js +0 -113
  119. package/dist/libs/crud-pro/models/ServiceHub.d.ts +0 -20
  120. package/dist/libs/crud-pro/models/ServiceHub.js +0 -2
  121. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +0 -22
  122. package/dist/libs/crud-pro/models/SqlCfgModel.js +0 -40
  123. package/dist/libs/crud-pro/models/SqlSegArg.d.ts +0 -6
  124. package/dist/libs/crud-pro/models/SqlSegArg.js +0 -12
  125. package/dist/libs/crud-pro/models/Transaction.d.ts +0 -29
  126. package/dist/libs/crud-pro/models/Transaction.js +0 -67
  127. package/dist/libs/crud-pro/models/TransactionMySQL.d.ts +0 -28
  128. package/dist/libs/crud-pro/models/TransactionMySQL.js +0 -76
  129. package/dist/libs/crud-pro/models/TransactionPostgres.d.ts +0 -28
  130. package/dist/libs/crud-pro/models/TransactionPostgres.js +0 -85
  131. package/dist/libs/crud-pro/models/TransactionSqlServer.d.ts +0 -34
  132. package/dist/libs/crud-pro/models/TransactionSqlServer.js +0 -92
  133. package/dist/libs/crud-pro/models/keys.d.ts +0 -106
  134. package/dist/libs/crud-pro/models/keys.js +0 -149
  135. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +0 -10
  136. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +0 -61
  137. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.d.ts +0 -9
  138. package/dist/libs/crud-pro/services/CrudProExecuteFuncService.js +0 -112
  139. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.d.ts +0 -17
  140. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +0 -227
  141. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.d.ts +0 -9
  142. package/dist/libs/crud-pro/services/CrudProFieldUpdateService.js +0 -51
  143. package/dist/libs/crud-pro/services/CrudProFieldValidateService.d.ts +0 -13
  144. package/dist/libs/crud-pro/services/CrudProFieldValidateService.js +0 -148
  145. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +0 -24
  146. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +0 -342
  147. package/dist/libs/crud-pro/services/CrudProGenSqlService.d.ts +0 -25
  148. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +0 -174
  149. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.d.ts +0 -32
  150. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +0 -333
  151. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +0 -28
  152. package/dist/libs/crud-pro/services/CrudProServiceBase.js +0 -78
  153. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +0 -8
  154. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +0 -53
  155. package/dist/libs/crud-pro/services/CurdProServiceHub.d.ts +0 -32
  156. package/dist/libs/crud-pro/services/CurdProServiceHub.js +0 -64
  157. package/dist/libs/crud-pro/sql.txt +0 -120
  158. package/dist/libs/crud-pro/utils/CompareUtils.d.ts +0 -9
  159. package/dist/libs/crud-pro/utils/CompareUtils.js +0 -25
  160. package/dist/libs/crud-pro/utils/DatabaseName.d.ts +0 -9
  161. package/dist/libs/crud-pro/utils/DatabaseName.js +0 -29
  162. package/dist/libs/crud-pro/utils/DateTimeUtils.d.ts +0 -7
  163. package/dist/libs/crud-pro/utils/DateTimeUtils.js +0 -21
  164. package/dist/libs/crud-pro/utils/MemoryRefreshCache.d.ts +0 -19
  165. package/dist/libs/crud-pro/utils/MemoryRefreshCache.js +0 -47
  166. package/dist/libs/crud-pro/utils/MessageParseUtils.d.ts +0 -5
  167. package/dist/libs/crud-pro/utils/MessageParseUtils.js +0 -33
  168. package/dist/libs/crud-pro/utils/MixinUtils.d.ts +0 -39
  169. package/dist/libs/crud-pro/utils/MixinUtils.js +0 -255
  170. package/dist/libs/crud-pro/utils/ModelUtils.d.ts +0 -11
  171. package/dist/libs/crud-pro/utils/ModelUtils.js +0 -49
  172. package/dist/libs/crud-pro/utils/MultiKeyMap.d.ts +0 -11
  173. package/dist/libs/crud-pro/utils/MultiKeyMap.js +0 -63
  174. package/dist/libs/crud-pro/utils/SqlFuncUtils.d.ts +0 -5
  175. package/dist/libs/crud-pro/utils/SqlFuncUtils.js +0 -29
  176. package/dist/libs/crud-pro/utils/TypeUtils.d.ts +0 -40
  177. package/dist/libs/crud-pro/utils/TypeUtils.js +0 -166
  178. package/dist/libs/crud-pro/utils/ValidateUtils.d.ts +0 -3
  179. package/dist/libs/crud-pro/utils/ValidateUtils.js +0 -165
  180. package/dist/libs/crud-pro/utils/pool/MySQLUtils.d.ts +0 -3
  181. package/dist/libs/crud-pro/utils/pool/MySQLUtils.js +0 -19
  182. package/dist/libs/crud-pro/utils/pool/PostgresUtils.d.ts +0 -3
  183. package/dist/libs/crud-pro/utils/pool/PostgresUtils.js +0 -20
  184. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.d.ts +0 -3
  185. package/dist/libs/crud-pro/utils/pool/SqlServerUtils.js +0 -20
  186. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.d.ts +0 -4
  187. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +0 -21
  188. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.d.ts +0 -2
  189. package/dist/libs/crud-pro/utils/sqlConvert/convertMsSql.js +0 -11
  190. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.d.ts +0 -2
  191. package/dist/libs/crud-pro/utils/sqlConvert/convertPgSql.js +0 -11
  192. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.d.ts +0 -2
  193. package/dist/libs/crud-pro/utils/sqlConvert/convertPgType.js +0 -128
  194. package/dist/libs/utils/common-dto.d.ts +0 -18
  195. package/dist/libs/utils/common-dto.js +0 -40
  196. package/dist/libs/utils/crypto-utils.d.ts +0 -3
  197. package/dist/libs/utils/crypto-utils.js +0 -46
  198. package/dist/libs/utils/fatcms-request.d.ts +0 -30
  199. package/dist/libs/utils/fatcms-request.js +0 -104
  200. package/dist/libs/utils/functions.d.ts +0 -4
  201. package/dist/libs/utils/functions.js +0 -63
  202. package/dist/libs/utils/ordernum-utils.d.ts +0 -2
  203. package/dist/libs/utils/ordernum-utils.js +0 -13
  204. package/dist/libs/utils/parseConfig.d.ts +0 -7
  205. package/dist/libs/utils/parseConfig.js +0 -44
  206. package/dist/libs/utils/parseCreateSql.d.ts +0 -5
  207. package/dist/libs/utils/parseCreateSql.js +0 -86
  208. package/dist/libs/utils/render-utils.d.ts +0 -28
  209. package/dist/libs/utils/render-utils.js +0 -135
  210. package/dist/middleware/forbidden.middleware.d.ts +0 -10
  211. package/dist/middleware/forbidden.middleware.js +0 -70
  212. package/dist/middleware/global.middleware.d.ts +0 -10
  213. package/dist/middleware/global.middleware.js +0 -246
  214. package/dist/middleware/permission.middleware.d.ts +0 -18
  215. package/dist/middleware/permission.middleware.js +0 -74
  216. package/dist/middleware/tx.middleware.d.ts +0 -9
  217. package/dist/middleware/tx.middleware.js +0 -40
  218. package/dist/models/SystemEntities.d.ts +0 -98
  219. package/dist/models/SystemEntities.js +0 -2
  220. package/dist/models/SystemPerm.d.ts +0 -95
  221. package/dist/models/SystemPerm.js +0 -100
  222. package/dist/models/SystemTables.d.ts +0 -27
  223. package/dist/models/SystemTables.js +0 -30
  224. package/dist/models/bizmodels.d.ts +0 -69
  225. package/dist/models/bizmodels.js +0 -34
  226. package/dist/models/contextLogger.d.ts +0 -25
  227. package/dist/models/contextLogger.js +0 -112
  228. package/dist/models/devops.d.ts +0 -12
  229. package/dist/models/devops.js +0 -19
  230. package/dist/models/userSession.d.ts +0 -61
  231. package/dist/models/userSession.js +0 -165
  232. package/dist/schedule/index.d.ts +0 -3
  233. package/dist/schedule/index.js +0 -69
  234. package/dist/service/AuthService.d.ts +0 -70
  235. package/dist/service/AuthService.js +0 -248
  236. package/dist/service/EnumInfoService.d.ts +0 -30
  237. package/dist/service/EnumInfoService.js +0 -123
  238. package/dist/service/FileCenterService.d.ts +0 -43
  239. package/dist/service/FileCenterService.js +0 -347
  240. package/dist/service/SysConfigService.d.ts +0 -7
  241. package/dist/service/SysConfigService.js +0 -45
  242. package/dist/service/UserAccountService.d.ts +0 -23
  243. package/dist/service/UserAccountService.js +0 -103
  244. package/dist/service/UserSessionService.d.ts +0 -16
  245. package/dist/service/UserSessionService.js +0 -85
  246. package/dist/service/VisitStatService.d.ts +0 -14
  247. package/dist/service/VisitStatService.js +0 -165
  248. package/dist/service/WorkbenchService.d.ts +0 -20
  249. package/dist/service/WorkbenchService.js +0 -153
  250. package/dist/service/anyapi/AnyApiSandboxService.d.ts +0 -15
  251. package/dist/service/anyapi/AnyApiSandboxService.js +0 -122
  252. package/dist/service/anyapi/AnyApiService.d.ts +0 -27
  253. package/dist/service/anyapi/AnyApiService.js +0 -179
  254. package/dist/service/base/ApiBaseService.d.ts +0 -15
  255. package/dist/service/base/ApiBaseService.js +0 -50
  256. package/dist/service/base/ApiRateLimiter.d.ts +0 -10
  257. package/dist/service/base/ApiRateLimiter.js +0 -51
  258. package/dist/service/base/BaseService.d.ts +0 -29
  259. package/dist/service/base/BaseService.js +0 -79
  260. package/dist/service/base/RedisCacheService.d.ts +0 -13
  261. package/dist/service/base/RedisCacheService.js +0 -50
  262. package/dist/service/crudstd/CrudStdActionService.d.ts +0 -17
  263. package/dist/service/crudstd/CrudStdActionService.js +0 -32
  264. package/dist/service/crudstd/CrudStdConstant.d.ts +0 -58
  265. package/dist/service/crudstd/CrudStdConstant.js +0 -64
  266. package/dist/service/crudstd/CrudStdRelationService.d.ts +0 -10
  267. package/dist/service/crudstd/CrudStdRelationService.js +0 -85
  268. package/dist/service/crudstd/CrudStdService.d.ts +0 -50
  269. package/dist/service/crudstd/CrudStdService.js +0 -182
  270. package/dist/service/curd/CurdMixByAccountService.d.ts +0 -9
  271. package/dist/service/curd/CurdMixByAccountService.js +0 -87
  272. package/dist/service/curd/CurdMixByDictService.d.ts +0 -13
  273. package/dist/service/curd/CurdMixByDictService.js +0 -111
  274. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +0 -22
  275. package/dist/service/curd/CurdMixByLinkToCustomService.js +0 -154
  276. package/dist/service/curd/CurdMixBySysConfigService.d.ts +0 -9
  277. package/dist/service/curd/CurdMixBySysConfigService.js +0 -78
  278. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +0 -10
  279. package/dist/service/curd/CurdMixByWorkbenchService.js +0 -76
  280. package/dist/service/curd/CurdMixService.d.ts +0 -17
  281. package/dist/service/curd/CurdMixService.js +0 -76
  282. package/dist/service/curd/CurdMixUtils.d.ts +0 -28
  283. package/dist/service/curd/CurdMixUtils.js +0 -201
  284. package/dist/service/curd/CurdProService.d.ts +0 -39
  285. package/dist/service/curd/CurdProService.js +0 -322
  286. package/dist/service/proxyapi/ProxyApiLoadService.d.ts +0 -21
  287. package/dist/service/proxyapi/ProxyApiLoadService.js +0 -164
  288. package/dist/service/proxyapi/ProxyApiService.d.ts +0 -60
  289. package/dist/service/proxyapi/ProxyApiService.js +0 -260
  290. package/dist/service/proxyapi/ProxyApiUtils.d.ts +0 -15
  291. package/dist/service/proxyapi/ProxyApiUtils.js +0 -34
  292. package/dist/service/proxyapi/RouteHandler.d.ts +0 -5
  293. package/dist/service/proxyapi/RouteHandler.js +0 -9
  294. package/dist/service/proxyapi/RouteTrie.d.ts +0 -12
  295. package/dist/service/proxyapi/RouteTrie.js +0 -63
  296. package/dist/service/proxyapi/WeightedRandom.d.ts +0 -9
  297. package/dist/service/proxyapi/WeightedRandom.js +0 -31
  298. package/dist/service/proxyapi/WeightedRoundRobin.d.ts +0 -8
  299. package/dist/service/proxyapi/WeightedRoundRobin.js +0 -32
  300. package/dist/views/404_app.html +0 -31
  301. package/dist/views/404_workbench.html +0 -34
  302. package/dist/views/static/favicon.ico +0 -0
  303. package/src/config/config.default.ts +0 -172
  304. package/src/config/seed/aeskey.txt +0 -1
  305. package/src/config/utils.ts +0 -23
  306. package/src/configuration.ts +0 -83
  307. package/src/controller/base/BaseApiController.ts +0 -145
  308. package/src/controller/gateway/AnyApiGatewayController.ts +0 -33
  309. package/src/controller/gateway/CrudMtdGatewayController.ts +0 -107
  310. package/src/controller/gateway/CrudStdGatewayController.ts +0 -101
  311. package/src/controller/gateway/DocGatewayController.ts +0 -165
  312. package/src/controller/gateway/FileController.ts +0 -110
  313. package/src/controller/gateway/ProxyApiGatewayController.ts +0 -47
  314. package/src/controller/gateway/PublicApiController.ts +0 -145
  315. package/src/controller/gateway/StaticController.ts +0 -303
  316. package/src/controller/helpers.controller.ts +0 -161
  317. package/src/controller/home.controller.ts +0 -71
  318. package/src/controller/manage/AnyApiMangeApi.ts +0 -66
  319. package/src/controller/manage/AppLogMangeApi.ts +0 -53
  320. package/src/controller/manage/AppMangeApi.ts +0 -53
  321. package/src/controller/manage/AppPageMangeApi.ts +0 -52
  322. package/src/controller/manage/AppSchemaHistoryApi.ts +0 -49
  323. package/src/controller/manage/CrudMethodsMangeApi.ts +0 -49
  324. package/src/controller/manage/CrudStandardDesignApi.ts +0 -353
  325. package/src/controller/manage/DataDictManageApi.ts +0 -78
  326. package/src/controller/manage/DeployManageApi.ts +0 -179
  327. package/src/controller/manage/DocLibManageApi.ts +0 -69
  328. package/src/controller/manage/DocManageApi.ts +0 -99
  329. package/src/controller/manage/FileManageApi.ts +0 -45
  330. package/src/controller/manage/LowCodeTplManageApi.ts +0 -52
  331. package/src/controller/manage/MenuManageApi.ts +0 -63
  332. package/src/controller/manage/ProxyApiMangeApi.ts +0 -52
  333. package/src/controller/manage/SuperAdminManageApi.ts +0 -138
  334. package/src/controller/manage/SysConfigMangeApi.ts +0 -95
  335. package/src/controller/manage/SystemInfoManageApi.ts +0 -48
  336. package/src/controller/manage/UserAccountManageApi.ts +0 -88
  337. package/src/controller/manage/WorkbenchMangeApi.ts +0 -72
  338. package/src/controller/medstatistic/MedAdminController.ts +0 -221
  339. package/src/controller/medstatistic/MedClientController.ts +0 -188
  340. package/src/controller/medstatistic/MedMessageService.ts +0 -89
  341. package/src/controller/medstatistic/MedScoreService.ts +0 -108
  342. package/src/controller/medstatistic/constants.ts +0 -63
  343. package/src/controller/myinfo/AuthController.ts +0 -174
  344. package/src/controller/myinfo/MyInfoController.ts +0 -32
  345. package/src/controller/render/AppRenderController.ts +0 -76
  346. package/src/controller/test.controller.ts +0 -37
  347. package/src/filter/default.filter.ts +0 -13
  348. package/src/filter/notfound.filter.ts +0 -10
  349. package/src/index.ts +0 -71
  350. package/src/interface.ts +0 -31
  351. package/src/libs/crud-pro/CrudPro.ts +0 -158
  352. package/src/libs/crud-pro/defaultConfigs.ts +0 -13
  353. package/src/libs/crud-pro/exceptions.ts +0 -124
  354. package/src/libs/crud-pro/interfaces.ts +0 -183
  355. package/src/libs/crud-pro/models/ExecuteContext.ts +0 -111
  356. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +0 -86
  357. package/src/libs/crud-pro/models/FuncContext.ts +0 -21
  358. package/src/libs/crud-pro/models/RequestCfgModel.ts +0 -141
  359. package/src/libs/crud-pro/models/RequestModel.ts +0 -141
  360. package/src/libs/crud-pro/models/ServiceHub.ts +0 -32
  361. package/src/libs/crud-pro/models/SqlCfgModel.ts +0 -52
  362. package/src/libs/crud-pro/models/SqlSegArg.ts +0 -13
  363. package/src/libs/crud-pro/models/Transaction.ts +0 -74
  364. package/src/libs/crud-pro/models/TransactionMySQL.ts +0 -79
  365. package/src/libs/crud-pro/models/TransactionPostgres.ts +0 -91
  366. package/src/libs/crud-pro/models/TransactionSqlServer.ts +0 -107
  367. package/src/libs/crud-pro/models/keys.ts +0 -159
  368. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +0 -75
  369. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +0 -128
  370. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +0 -279
  371. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +0 -60
  372. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +0 -180
  373. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +0 -373
  374. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +0 -202
  375. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +0 -397
  376. package/src/libs/crud-pro/services/CrudProServiceBase.ts +0 -98
  377. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +0 -59
  378. package/src/libs/crud-pro/services/CurdProServiceHub.ts +0 -92
  379. package/src/libs/crud-pro/sql.txt +0 -120
  380. package/src/libs/crud-pro/utils/CompareUtils.ts +0 -23
  381. package/src/libs/crud-pro/utils/DatabaseName.ts +0 -40
  382. package/src/libs/crud-pro/utils/DateTimeUtils.ts +0 -20
  383. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +0 -64
  384. package/src/libs/crud-pro/utils/MessageParseUtils.ts +0 -33
  385. package/src/libs/crud-pro/utils/MixinUtils.ts +0 -285
  386. package/src/libs/crud-pro/utils/ModelUtils.ts +0 -55
  387. package/src/libs/crud-pro/utils/MultiKeyMap.ts +0 -72
  388. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +0 -29
  389. package/src/libs/crud-pro/utils/TypeUtils.ts +0 -188
  390. package/src/libs/crud-pro/utils/ValidateUtils.ts +0 -167
  391. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +0 -20
  392. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +0 -22
  393. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +0 -22
  394. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +0 -26
  395. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +0 -11
  396. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +0 -11
  397. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +0 -129
  398. package/src/libs/utils/common-dto.ts +0 -52
  399. package/src/libs/utils/crypto-utils.ts +0 -52
  400. package/src/libs/utils/fatcms-request.ts +0 -115
  401. package/src/libs/utils/functions.ts +0 -67
  402. package/src/libs/utils/ordernum-utils.ts +0 -18
  403. package/src/libs/utils/parseConfig.ts +0 -62
  404. package/src/libs/utils/parseCreateSql.ts +0 -91
  405. package/src/libs/utils/render-utils.ts +0 -184
  406. package/src/middleware/forbidden.middleware.ts +0 -71
  407. package/src/middleware/global.middleware.ts +0 -278
  408. package/src/middleware/permission.middleware.ts +0 -81
  409. package/src/middleware/tx.middleware.ts +0 -30
  410. package/src/models/SystemEntities.ts +0 -115
  411. package/src/models/SystemPerm.ts +0 -105
  412. package/src/models/SystemTables.ts +0 -30
  413. package/src/models/bizmodels.ts +0 -89
  414. package/src/models/contextLogger.ts +0 -132
  415. package/src/models/devops.ts +0 -17
  416. package/src/models/userSession.ts +0 -216
  417. package/src/schedule/index.ts +0 -73
  418. package/src/service/AuthService.ts +0 -270
  419. package/src/service/EnumInfoService.ts +0 -129
  420. package/src/service/FileCenterService.ts +0 -394
  421. package/src/service/SysConfigService.ts +0 -34
  422. package/src/service/UserAccountService.ts +0 -100
  423. package/src/service/UserSessionService.ts +0 -81
  424. package/src/service/VisitStatService.ts +0 -179
  425. package/src/service/WorkbenchService.ts +0 -160
  426. package/src/service/anyapi/AnyApiSandboxService.ts +0 -121
  427. package/src/service/anyapi/AnyApiService.ts +0 -184
  428. package/src/service/base/ApiBaseService.ts +0 -42
  429. package/src/service/base/ApiRateLimiter.ts +0 -59
  430. package/src/service/base/BaseService.ts +0 -74
  431. package/src/service/base/RedisCacheService.ts +0 -38
  432. package/src/service/crudstd/CrudStdActionService.ts +0 -27
  433. package/src/service/crudstd/CrudStdConstant.ts +0 -62
  434. package/src/service/crudstd/CrudStdRelationService.ts +0 -78
  435. package/src/service/crudstd/CrudStdService.ts +0 -188
  436. package/src/service/curd/CurdMixByAccountService.ts +0 -83
  437. package/src/service/curd/CurdMixByDictService.ts +0 -113
  438. package/src/service/curd/CurdMixByLinkToCustomService.ts +0 -167
  439. package/src/service/curd/CurdMixBySysConfigService.ts +0 -78
  440. package/src/service/curd/CurdMixByWorkbenchService.ts +0 -68
  441. package/src/service/curd/CurdMixService.ts +0 -65
  442. package/src/service/curd/CurdMixUtils.ts +0 -248
  443. package/src/service/curd/CurdProService.ts +0 -379
  444. package/src/service/proxyapi/ProxyApiLoadService.ts +0 -165
  445. package/src/service/proxyapi/ProxyApiService.ts +0 -262
  446. package/src/service/proxyapi/ProxyApiUtils.ts +0 -32
  447. package/src/service/proxyapi/RouteHandler.ts +0 -8
  448. package/src/service/proxyapi/RouteTrie.ts +0 -74
  449. package/src/service/proxyapi/WeightedRandom.ts +0 -37
  450. package/src/service/proxyapi/WeightedRoundRobin.ts +0 -44
  451. package/src/views/404_app.html +0 -31
  452. package/src/views/404_workbench.html +0 -34
  453. package/src/views/static/favicon.ico +0 -0
@@ -1,373 +0,0 @@
1
- import {SqlSegArg} from '../models/SqlSegArg';
2
- import {MixinUtils} from '../utils/MixinUtils';
3
- import {KeysOfConditions, SqlDbType} from '../models/keys';
4
- import {CommonException, Exceptions} from '../exceptions';
5
- import {ICompareCondition, IRequestCondition} from '../interfaces';
6
- import {TypeUtils} from '../utils/TypeUtils';
7
- import {SqlCfgModel} from "../models/SqlCfgModel";
8
- import {toSqlColumnName} from '../utils/sqlConvert/convertColumnName';
9
-
10
- const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils;
11
- const { isBasicType, isNumber } = TypeUtils;
12
-
13
- const createFunc = (sqlCfg: SqlCfgModel) => {
14
- return {
15
- toSqlColumnName: (columnName: string): string => {
16
- return toSqlColumnName(columnName, sqlCfg)
17
- },
18
- toMatchSqlColumnName: (columnName: string): string => {
19
- const arr = columnName.split(',');
20
- return arr
21
- .map(s => toSqlColumnName(s.trim(), sqlCfg))
22
- .join(',');
23
- }
24
- }
25
- }
26
-
27
- class ValueChecker {
28
- checkBasicArrayAndNotEmpty(value0: any, message: string) {
29
- // 不能为空
30
- if (!value0 || !Array.isArray(value0) || value0.length === 0) {
31
- throw new CommonException(Exceptions.REQUEST_PARAM_ERROR, message);
32
- }
33
-
34
- // 元素必须是基本数据类型
35
- for (let i = 0; i < value0.length; i++) {
36
- const value0Element = value0[i];
37
- if (!TypeUtils.isBasicType(value0Element)) {
38
- throw new CommonException(Exceptions.REQUEST_PARAM_ERROR, message);
39
- }
40
- }
41
- }
42
- }
43
-
44
- function hasCompareKey(compare: string): boolean {
45
- return KeysOfConditions.COMPARE_KEYS.has(compare);
46
- }
47
-
48
- const valueChecker = new ValueChecker();
49
-
50
- class CrudProGenSqlCondition {
51
- private readonly sqlCfg: SqlCfgModel;
52
- constructor(sqlCfg: SqlCfgModel) {
53
- this.sqlCfg = sqlCfg;
54
- }
55
-
56
- generateCondition(condition: any): SqlSegArg {
57
- if (isEmpty(condition)) {
58
- return new SqlSegArg(' 1=1 ');
59
- }
60
- const sqlArgModel = this.generateByLogicalKey(condition);
61
- const sql = ' 1=1 and ' + sqlArgModel.sql;
62
- return new SqlSegArg(sql, sqlArgModel.args);
63
- }
64
-
65
- /**
66
- * condition = {$or:[{name:'zhangsan'},{name:'lisi'},{age: {$gt:18}}],sex:1}
67
- * where (name = 'zhangsan' or name = 'lisi' or age > 18) and sex = 1
68
- * @param condition
69
- * @private
70
- */
71
- private generateByLogicalKey(condition: IRequestCondition): SqlSegArg {
72
- if (isEmpty(condition)) {
73
- return null;
74
- }
75
- const { toSqlColumnName } = createFunc(this.sqlCfg);
76
-
77
- const tmpSqlList = [];
78
- const tmpArgList = [];
79
-
80
- const keys = Object.keys(condition);
81
- for (let i = 0; i < keys.length; i++) {
82
- const key = keys[i];
83
- const value = condition[key];
84
-
85
- if (!hasCompareKey(key)) {
86
- // 第一层的key,不能是比较运算符。
87
- // OR
88
- if (equalsIgnoreCase(KeysOfConditions.$OR, key)) {
89
- TypeUtils.assertJsonArray(value, Exceptions.REQUEST_OR_PARAM_MUST_ARRAY);
90
-
91
- const a = this.generateByLogicalOR(value);
92
- if (a != null) {
93
- tmpSqlList.push(a.sql);
94
- if (isNotEmpty(a.args)) {
95
- tmpArgList.push(...a.args);
96
- }
97
- }
98
- }
99
-
100
- // AND
101
- else if (TypeUtils.isBasicType(value)) {
102
- tmpSqlList.push(toSqlColumnName(key) + '= ?');
103
- tmpArgList.push(value);
104
- } else {
105
- // AND
106
- const a = this.generateByCompareKey(key, value);
107
-
108
- if (a != null) {
109
- tmpSqlList.push(a.sql);
110
- if (MixinUtils.isNotEmpty(a.args)) {
111
- tmpArgList.push(...a.args);
112
- }
113
- }
114
- }
115
- }
116
- }
117
-
118
- if (isEmpty(tmpSqlList)) {
119
- return null;
120
- }
121
-
122
- // const sql = "(" + StringUtils.join(tmpSqlList, " AND ") + ")";
123
- const sql = '(' + tmpSqlList.join(' AND ') + ')';
124
- return new SqlSegArg(sql, tmpArgList);
125
- }
126
-
127
- private generateByLogicalOR(jsonArray: IRequestCondition[]): SqlSegArg {
128
- if (MixinUtils.isEmpty(jsonArray)) {
129
- return null;
130
- }
131
-
132
- const tmpSqlList = [];
133
- const tmpArgList = [];
134
-
135
- for (let i = 0; i < jsonArray.length; i++) {
136
- const jsonObject = jsonArray[i];
137
- const a = this.generateByLogicalKey(jsonObject);
138
- if (a != null) {
139
- tmpSqlList.push(a.sql);
140
- if (MixinUtils.isNotEmpty(a.args)) {
141
- tmpArgList.push(...a.args);
142
- }
143
- }
144
- }
145
- const sql = '(' + tmpSqlList.join(' OR ') + ')';
146
- return new SqlSegArg(sql, tmpArgList);
147
- }
148
-
149
- // 例如:
150
- // {name:1, age:{"$gt":5, "$lt":10}, } ==> name = 1 and (age > 5 and age < 10)
151
- // {name:1, age:{"$nin":[1,2,3],"$lt":10} } ==> name = 1 and (age not in (1,2,3) and age < 10)
152
- // 比较运算符
153
- private generateByCompareKey(key: string, map: ICompareCondition): SqlSegArg {
154
- if (isEmpty(map)) {
155
- return null;
156
- }
157
-
158
- const { toSqlColumnName, toMatchSqlColumnName } = createFunc(this.sqlCfg);
159
-
160
- this.generateByCompareKeyCheckParam(key, map);
161
-
162
- const tmpSqlList = [];
163
- const tmpArgList = [];
164
-
165
- let hasNoArgSql = false;
166
- const compareSet = Object.keys(map);
167
-
168
- for (let i = 0; i < compareSet.length; i++) {
169
- const compare = compareSet[i];
170
-
171
- if (hasCompareKey(compare)) {
172
- const value0 = map[compare];
173
-
174
- let tmpSql = '';
175
-
176
- if (equalsIgnoreCase(KeysOfConditions.$NULL, compare)) {
177
- tmpSql = `${toSqlColumnName(key)} is null `;
178
- hasNoArgSql = true;
179
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_NULL, compare)) {
180
- tmpSql = `${toSqlColumnName(key)} is not null `;
181
- hasNoArgSql = true;
182
- } else if (equalsIgnoreCase(KeysOfConditions.$GT, compare)) {
183
- tmpArgList.push(value0);
184
- tmpSql = `${toSqlColumnName(key)} > ?`;
185
- } else if (equalsIgnoreCase(KeysOfConditions.$GTE, compare)) {
186
- tmpArgList.push(value0);
187
- tmpSql = `${toSqlColumnName(key)} >= ?`;
188
- } else if (equalsIgnoreCase(KeysOfConditions.$LT, compare)) {
189
- tmpArgList.push(value0);
190
- tmpSql = `${toSqlColumnName(key)} < ?`;
191
- } else if (equalsIgnoreCase(KeysOfConditions.$LTE, compare)) {
192
- tmpArgList.push(value0);
193
- tmpSql = `${toSqlColumnName(key)} <= ?`;
194
- } else if (equalsIgnoreCase(KeysOfConditions.$NE, compare)) {
195
- tmpArgList.push(value0);
196
- tmpSql = `${toSqlColumnName(key)} != ?`;
197
- } else if (equalsIgnoreCase(KeysOfConditions.$IN, compare)) {
198
- const array = [...value0];
199
- if (isNotEmpty(array)) {
200
- const pm = array.map(() => '?').join(',');
201
- tmpSql = `${toSqlColumnName(key)} in (${pm})`;
202
- tmpArgList.push(...array);
203
- }
204
- } else if (equalsIgnoreCase(KeysOfConditions.$NIN, compare)) {
205
- const array = [...value0];
206
- if (isNotEmpty(array)) {
207
- const pm = array.map(() => '?').join(',');
208
- tmpSql = `${toSqlColumnName(key)} not in (${pm})`;
209
- tmpArgList.push(...array);
210
- }
211
- } else if (equalsIgnoreCase(KeysOfConditions.$LIKE, compare)) {
212
- tmpArgList.push(value0);
213
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat(?, '%')`; // like前缀匹配
214
-
215
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
216
- tmpSql = `${toSqlColumnName(key)} like concat(?, '%')`; // like前缀匹配
217
- }
218
-
219
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE, compare)) {
220
- tmpArgList.push(value0);
221
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat(?, '%')`;
222
-
223
-
224
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
225
- tmpSql = `${toSqlColumnName(key)} not like concat(?, '%')`;
226
- }
227
-
228
- }
229
-
230
-
231
- else if (equalsIgnoreCase(KeysOfConditions.$LIKE_INCLUDE, compare)) {
232
- tmpArgList.push(value0);
233
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat('%', ?, '%')`; // like包含
234
-
235
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
236
- tmpSql = `${toSqlColumnName(key)} like concat('%', ?, '%')`; // like包含
237
- }
238
-
239
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
240
- tmpArgList.push(value0);
241
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat('%',?, '%')`; // like不包含
242
-
243
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
244
- tmpSql = `${toSqlColumnName(key)} not like concat('%',?, '%')`; // like不包含
245
- }
246
-
247
- }
248
-
249
-
250
- else if (equalsIgnoreCase(KeysOfConditions.$MATCH, compare)) {
251
- tmpArgList.push(value0);
252
- tmpSql = `match(${toMatchSqlColumnName(key)}) against(?)`;
253
- } else if (equalsIgnoreCase(KeysOfConditions.$MATCH_BOOL, compare)) {
254
- tmpArgList.push(value0);
255
- tmpSql = `match(${toMatchSqlColumnName(key)}) against( ? in boolean mode)`;
256
- } else if (equalsIgnoreCase(KeysOfConditions.$RANGE, compare)) {
257
- const array = [...value0];
258
- if (isNotEmpty(array) && array.length === 2) {
259
- tmpSql = `(${toSqlColumnName(key)} between ? and ? )`;
260
- tmpArgList.push(...array);
261
- }
262
- }
263
-
264
- tmpSqlList.push(tmpSql);
265
- }
266
- }
267
-
268
- if (isEmpty(tmpArgList) && !hasNoArgSql) {
269
- return null;
270
- }
271
-
272
- const sql = '( ' + tmpSqlList.join(' and ') + ' )';
273
- return new SqlSegArg(sql, tmpArgList);
274
- }
275
-
276
- /**
277
- * 参数校验
278
- * @param key
279
- * @param map
280
- * @private
281
- */
282
- private generateByCompareKeyCheckParam(key: string, map: ICompareCondition) {
283
- if (isEmpty(map)) {
284
- return null;
285
- }
286
-
287
- const compareSet = Object.keys(map);
288
-
289
- const throwCommonException = (name: string, type: string) => {
290
- throw new CommonException(Exceptions.REQUEST_PARAM_ERROR, `${name}参数必须是${type}`);
291
- };
292
-
293
- for (let i = 0; i < compareSet.length; i++) {
294
- const compare = compareSet[i];
295
-
296
- if (hasCompareKey(compare)) {
297
- const value0 = map[compare];
298
-
299
- if (equalsIgnoreCase(KeysOfConditions.$GT, compare)) {
300
- if (!isBasicType(value0)) {
301
- throwCommonException(KeysOfConditions.$GT, '字符串、数字');
302
- }
303
- } else if (equalsIgnoreCase(KeysOfConditions.$GTE, compare)) {
304
- if (!isBasicType(value0)) {
305
- throwCommonException(KeysOfConditions.$GTE, '字符串、数字');
306
- }
307
- } else if (equalsIgnoreCase(KeysOfConditions.$LT, compare)) {
308
- if (!isBasicType(value0)) {
309
- throwCommonException(KeysOfConditions.$LT, '字符串、数字');
310
- }
311
- } else if (equalsIgnoreCase(KeysOfConditions.$LTE, compare)) {
312
- if (!isBasicType(value0)) {
313
- throwCommonException(KeysOfConditions.$LTE, '字符串、数字');
314
- }
315
- } else if (equalsIgnoreCase(KeysOfConditions.$NE, compare)) {
316
- if (!isBasicType(value0)) {
317
- throwCommonException(KeysOfConditions.$NE, '字符串、数字');
318
- }
319
- } else if (equalsIgnoreCase(KeysOfConditions.$IN, compare)) {
320
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
321
- } else if (equalsIgnoreCase(KeysOfConditions.$NIN, compare)) {
322
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
323
- } else if (equalsIgnoreCase(KeysOfConditions.$LIKE, compare)) {
324
- if (!isBasicType(value0)) {
325
- throwCommonException(KeysOfConditions.$LIKE, '字符串');
326
- }
327
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE, compare)) {
328
- if (!isBasicType(value0)) {
329
- throwCommonException(KeysOfConditions.$NOT_LIKE, '字符串');
330
- }
331
- }
332
-
333
-
334
- else if (equalsIgnoreCase(KeysOfConditions.$LIKE_INCLUDE, compare)) {
335
- if (!isBasicType(value0)) {
336
- throwCommonException(KeysOfConditions.$LIKE_INCLUDE, '字符串');
337
- }
338
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
339
- if (!isBasicType(value0)) {
340
- throwCommonException(KeysOfConditions.$NOT_LIKE_INCLUDE, '字符串');
341
- }
342
- }
343
-
344
-
345
- else if (equalsIgnoreCase(KeysOfConditions.$MATCH, compare)) {
346
- if (!isBasicType(value0)) {
347
- throwCommonException(KeysOfConditions.$MATCH, '字符串');
348
- }
349
- } else if (equalsIgnoreCase(KeysOfConditions.$MATCH_BOOL, compare)) {
350
- if (!isBasicType(value0)) {
351
- throwCommonException(KeysOfConditions.$MATCH_BOOL, '字符串');
352
- }
353
- } else if (equalsIgnoreCase(KeysOfConditions.$RANGE, compare)) {
354
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是两个数字组成的数组`);
355
-
356
- const array = [...value0];
357
- if (isNotEmpty(array) && array.length === 2) {
358
- for (let j = 0; j < array.length; j++) {
359
- const arrayElement = array[j];
360
- if (!isNumber(arrayElement)) {
361
- throwCommonException(KeysOfConditions.$RANGE, '数组(两个数字)');
362
- }
363
- }
364
- } else {
365
- throwCommonException(KeysOfConditions.$RANGE, '数组(两个数字)');
366
- }
367
- }
368
- }
369
- }
370
- }
371
- }
372
-
373
- export { CrudProGenSqlCondition };
@@ -1,202 +0,0 @@
1
- import { CrudProServiceBase } from './CrudProServiceBase';
2
- import { CommonException, Exceptions } from '../exceptions';
3
- import { MixinUtils } from '../utils/MixinUtils';
4
- import {KeysOfSimpleSQL, KeysOfSqlResPicker, SqlDbType} from '../models/keys';
5
- import {RequestCfgModel} from "../models/RequestCfgModel";
6
-
7
- const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils;
8
-
9
- class CrudProGenSqlService extends CrudProServiceBase {
10
- public async generateSQLList() {
11
- const exeCtx = this.getExecuteContext();
12
- const reqCfg = exeCtx.getCfgModel();
13
- const sqlSimpleName = reqCfg.sqlSimpleName;
14
-
15
- // 简单模式
16
- const isSimpleMode = isNotEmpty(sqlSimpleName) && sqlSimpleName.startsWith('SIMPLE_');
17
-
18
- // 拼接简单模式的SQL
19
- if (isSimpleMode) {
20
- this.generateOriginSql();
21
- }
22
-
23
- await this.generateExecuteSql();
24
- }
25
-
26
- private generateOriginSql() {
27
- const exeCtx = this.getExecuteContext();
28
-
29
- const cfgModel = exeCtx.getCfgModel();
30
- const simpleSqlName = cfgModel.sqlSimpleName;
31
-
32
- // 只有当设置了simpleSqlName时,才启用内置的SQL生成
33
- if (isEmpty(simpleSqlName)) {
34
- return;
35
- }
36
-
37
- cfgModel.sqlCfgList = [];
38
-
39
- let sql1 = null;
40
- let sql2 = null;
41
- let sql3 = null;
42
- if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY, simpleSqlName)) {
43
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit';
44
- cfgModel.addSqlCfgModel('rows', sql1);
45
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_ONE, simpleSqlName)) {
46
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys limit 1';
47
- cfgModel.addSqlCfgModel('row', sql1, KeysOfSqlResPicker.RESULT_FIRST_ROW);
48
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_COUNT, simpleSqlName)) {
49
- sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition';
50
-
51
- cfgModel.addSqlCfgModel('total_count', sql1, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
52
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_PAGE, simpleSqlName)) {
53
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit ';
54
- sql2 = 'select count(0) as total_count from @@table where @@asWhere:condition';
55
-
56
- cfgModel.addSqlCfgModel('rows', sql1);
57
- cfgModel.addSqlCfgModel('total_count', sql2, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
58
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_DELETE, simpleSqlName)) {
59
- sql1 = this.generateOriginSqlForDelete(cfgModel);
60
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
61
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT, simpleSqlName)) {
62
- sql1 = this.generateOriginSqlForInsert(cfgModel);
63
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
64
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_UPDATE, simpleSqlName)) {
65
- sql1 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
66
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
67
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE, simpleSqlName)) {
68
- sql1 = this.generateOriginSqlForDuplicateInsert(cfgModel);
69
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
70
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE, simpleSqlName)) {
71
- sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition ';
72
- sql2 = 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )';
73
- sql3 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
74
-
75
- const insertWhen2 = {
76
- functionName: 'eq',
77
- functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
78
- };
79
- const updateWhen3 = {
80
- functionName: 'gt',
81
- functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
82
- };
83
-
84
- cfgModel.addSqlCfgModel('total_count', sql1, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
85
- cfgModel.addSqlCfgModel('insert_affected', sql2, KeysOfSqlResPicker.UPDATE_RESULT, insertWhen2);
86
- cfgModel.addSqlCfgModel('update_affected', sql3, KeysOfSqlResPicker.UPDATE_RESULT, updateWhen3);
87
- }
88
-
89
- if (isEmpty(sql1)) {
90
- throw new CommonException(Exceptions.CFG_NOT_SUPPORT_THE_SIMPLE_SQL, simpleSqlName);
91
- }
92
- }
93
-
94
- /**
95
- * 删除语句
96
- * @param cfgModel
97
- * @private
98
- */
99
- private generateOriginSqlForDelete(cfgModel: RequestCfgModel) : string {
100
- if (cfgModel.sqlDdType === SqlDbType.postgres) {
101
- return 'delete from @@table where @@asWhere:condition ';
102
- }
103
- if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
104
- return 'delete from @@table where @@asWhere:condition ';
105
- }
106
- return 'delete from @@table where @@asWhere:condition limit 100 '; // 删除操作,不能一次性删除太多
107
- }
108
-
109
- /**
110
- * 创建插入OR更新语句
111
- * @param cfgModel
112
- * @private
113
- */
114
- private generateOriginSqlForDuplicateInsert(cfgModel: RequestCfgModel) : string {
115
- if (cfgModel.sqlDdType === SqlDbType.postgres) {
116
- const uniqueColumn = cfgModel.uniqueColumn ; // id
117
- if (!Array.isArray(uniqueColumn) || uniqueColumn.length === 0) {
118
- throw new CommonException(Exceptions.CFG_ERROR_POSTGRES_UNIQUE_COLUMNS_NULL)
119
- }
120
- const unique_column = uniqueColumn.map((s)=>{
121
- return `"${s}"`;
122
- }).join(",")
123
- return `insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) ON CONFLICT (${unique_column}) DO UPDATE set @@asUpdate:data `; // 关键字的前后,必须有空格
124
- }
125
-
126
-
127
- if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
128
- const uniqueColumn = cfgModel.uniqueColumn ; // id
129
- if (uniqueColumn.length !== 1) {
130
- throw new CommonException(Exceptions.CFG_UNIQUE_COLUMN_COUNT_MUST_ONE);
131
- }
132
-
133
- const uniqueColumnStr = uniqueColumn[0];
134
- const uniqueColumnVal = "@@data." + uniqueColumnStr;
135
-
136
- const sql = "" +
137
- `IF EXISTS (SELECT 1 FROM @@table WHERE [${uniqueColumnStr}] = ${uniqueColumnVal})` +
138
- "BEGIN\n" +
139
- " UPDATE @@table\n" +
140
- " SET @@asUpdate:data\n" +
141
- ` WHERE [${uniqueColumnStr}] = ${uniqueColumnVal} ;\n` +
142
- "END\n" +
143
- "ELSE\n" +
144
- "BEGIN\n" +
145
- " INSERT INTO @@table ( @@asInsertKeys:data )\n" +
146
- " VALUES ( @@asInsertValues:data );\n" +
147
- "END";
148
-
149
- return sql;
150
- }
151
-
152
-
153
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) on duplicate key update @@asUpdate:data '; // 关键字的前后,必须有空格
154
- }
155
-
156
-
157
- /**
158
- * 创建插入语句
159
- * @param cfgModel
160
- * @private
161
- */
162
- private generateOriginSqlForInsert(cfgModel: RequestCfgModel): string {
163
- if (cfgModel.sqlDdType === SqlDbType.postgres) {
164
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) RETURNING * ';
165
- }
166
- if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
167
- return 'insert into @@table ( @@asInsertKeys:data ) OUTPUT INSERTED.* values( @@asInsertValues:data ) ';
168
- }
169
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )'; // 关键字的前后,必须有空格
170
- }
171
-
172
-
173
-
174
-
175
- private async generateExecuteSql() {
176
- const exeCtx = this.getExecuteContext();
177
-
178
- const reqCfgModel = exeCtx.getCfgModel();
179
- const sqlCfgList = reqCfgModel.sqlCfgList || [];
180
- const { sqlTable, sqlSchema, sqlDatabase, sqlDdType, maxLimit, columns, columnsRelation } = reqCfgModel;
181
-
182
- for (let i = 0; i < sqlCfgList.length; i++) {
183
- const sqlCfgModel = sqlCfgList[i];
184
-
185
- sqlCfgModel.sqlDdType = MixinUtils.selectNotEmpty(sqlCfgModel.sqlDdType, sqlDdType);
186
- sqlCfgModel.sqlDatabase = MixinUtils.selectNotEmpty(sqlCfgModel.sqlDatabase, sqlDatabase);
187
- sqlCfgModel.sqlSchema = MixinUtils.selectNotEmpty(sqlCfgModel.sqlSchema, sqlSchema);
188
- sqlCfgModel.sqlTable = MixinUtils.selectNotEmpty(sqlCfgModel.sqlTable, sqlTable);
189
- sqlCfgModel.maxLimit = MixinUtils.selectNotEmpty(sqlCfgModel.maxLimit, maxLimit);
190
- sqlCfgModel.columns = MixinUtils.selectNotEmpty(sqlCfgModel.columns, columns);
191
- sqlCfgModel.columnsRelation = MixinUtils.selectNotEmpty(sqlCfgModel.columnsRelation, columnsRelation);
192
-
193
- await this.serviceHub.convertOriginToExecuteSql(sqlCfgModel);
194
-
195
- exeCtx.getSqlCfgModels().push(sqlCfgModel);
196
- }
197
- }
198
-
199
-
200
- }
201
-
202
- export { CrudProGenSqlService };