midway-fatcms 0.0.1-beta.54 → 0.0.1-beta.56

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 (497) 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 -119
  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 +26 -26
  23. package/dist/controller/gateway/FileController.js +129 -129
  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 +27 -27
  27. package/dist/controller/gateway/PublicApiController.js +162 -162
  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 +395 -395
  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 +163 -163
  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 +106 -106
  125. package/dist/libs/crud-pro/models/keys.js +149 -149
  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 +112 -112
  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 +340 -340
  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 +49 -49
  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 -60
  187. package/dist/libs/global-config/global-config.js +36 -35
  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 +7 -7
  203. package/dist/libs/utils/parseConfig.js +44 -44
  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 +135 -135
  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 +99 -99
  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 -70
  247. package/dist/service/AuthService.js +259 -251
  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 +112 -112
  292. package/dist/service/crudstd/CrudStdService.d.ts +68 -66
  293. package/dist/service/crudstd/CrudStdService.js +347 -299
  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 +92 -92
  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 +51 -51
  309. package/dist/service/curd/CurdMixUtils.js +277 -277
  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 -79
  330. package/src/config/config.default.ts +179 -0
  331. package/src/config/seed/aeskey.txt +1 -0
  332. package/src/config/utils.ts +22 -0
  333. package/src/configuration.ts +109 -0
  334. package/src/controller/base/BaseApiController.ts +170 -0
  335. package/src/controller/gateway/AnyApiGatewayController.ts +1 -0
  336. package/src/controller/gateway/AsyncTaskController.ts +157 -0
  337. package/src/controller/gateway/CrudMtdGatewayController.ts +116 -0
  338. package/src/controller/gateway/CrudStdGatewayController.ts +87 -0
  339. package/src/controller/gateway/DocGatewayController.ts +173 -0
  340. package/src/controller/gateway/FileController.ts +109 -0
  341. package/src/controller/gateway/ProxyApiGatewayController.ts +47 -0
  342. package/src/controller/gateway/PublicApiController.ts +140 -0
  343. package/src/controller/gateway/StaticController.ts +296 -0
  344. package/src/controller/helpers.controller.ts +161 -0
  345. package/src/controller/home.controller.ts +66 -0
  346. package/src/controller/manage/AnyApiMangeApi.ts +66 -0
  347. package/src/controller/manage/AppLogMangeApi.ts +53 -0
  348. package/src/controller/manage/AppMangeApi.ts +53 -0
  349. package/src/controller/manage/AppPageMangeApi.ts +52 -0
  350. package/src/controller/manage/AppSchemaHistoryApi.ts +49 -0
  351. package/src/controller/manage/CrudMethodsMangeApi.ts +49 -0
  352. package/src/controller/manage/CrudStandardDesignApi.ts +406 -0
  353. package/src/controller/manage/DataDictManageApi.ts +78 -0
  354. package/src/controller/manage/DeployManageApi.ts +175 -0
  355. package/src/controller/manage/DocLibManageApi.ts +69 -0
  356. package/src/controller/manage/DocManageApi.ts +99 -0
  357. package/src/controller/manage/FileManageApi.ts +45 -0
  358. package/src/controller/manage/LowCodeTplManageApi.ts +52 -0
  359. package/src/controller/manage/MenuManageApi.ts +58 -0
  360. package/src/controller/manage/ProxyApiMangeApi.ts +52 -0
  361. package/src/controller/manage/SuperAdminManageApi.ts +139 -0
  362. package/src/controller/manage/SysConfigMangeApi.ts +95 -0
  363. package/src/controller/manage/SystemInfoManageApi.ts +53 -0
  364. package/src/controller/manage/UserAccountManageApi.ts +94 -0
  365. package/src/controller/manage/WorkbenchMangeApi.ts +72 -0
  366. package/src/controller/myinfo/AuthController.ts +108 -0
  367. package/src/controller/myinfo/MyInfoController.ts +32 -0
  368. package/src/controller/render/AppRenderController.ts +81 -0
  369. package/src/controller/test.controller.ts +37 -0
  370. package/src/filter/default.filter.ts +13 -0
  371. package/src/filter/notfound.filter.ts +10 -0
  372. package/src/index.ts +107 -0
  373. package/src/interface.ts +31 -0
  374. package/src/libs/crud-pro/CrudPro.ts +165 -0
  375. package/src/libs/crud-pro/defaultConfigs.ts +15 -0
  376. package/src/libs/crud-pro/exceptions.ts +124 -0
  377. package/src/libs/crud-pro/interfaces.ts +190 -0
  378. package/src/libs/crud-pro/models/ExecuteContext.ts +120 -0
  379. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +96 -0
  380. package/src/libs/crud-pro/models/FuncContext.ts +21 -0
  381. package/src/libs/crud-pro/models/RequestCfgModel.ts +141 -0
  382. package/src/libs/crud-pro/models/RequestModel.ts +141 -0
  383. package/src/libs/crud-pro/models/ResModel.ts +19 -0
  384. package/src/libs/crud-pro/models/ServiceHub.ts +32 -0
  385. package/src/libs/crud-pro/models/SqlCfgModel.ts +52 -0
  386. package/src/libs/crud-pro/models/SqlSegArg.ts +13 -0
  387. package/src/libs/crud-pro/models/Transaction.ts +83 -0
  388. package/src/libs/crud-pro/models/TransactionMySQL.ts +79 -0
  389. package/src/libs/crud-pro/models/TransactionPostgres.ts +91 -0
  390. package/src/libs/crud-pro/models/TransactionSqlServer.ts +102 -0
  391. package/src/libs/crud-pro/models/keys.ts +159 -0
  392. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +83 -0
  393. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +128 -0
  394. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +262 -0
  395. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +60 -0
  396. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +180 -0
  397. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +354 -0
  398. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +185 -0
  399. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +393 -0
  400. package/src/libs/crud-pro/services/CrudProServiceBase.ts +107 -0
  401. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +86 -0
  402. package/src/libs/crud-pro/services/CurdProServiceHub.ts +92 -0
  403. package/src/libs/crud-pro/sql.txt +120 -0
  404. package/src/libs/crud-pro/utils/CompareUtils.ts +23 -0
  405. package/src/libs/crud-pro/utils/DatabaseName.ts +60 -0
  406. package/src/libs/crud-pro/utils/DateTimeUtils.ts +20 -0
  407. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +64 -0
  408. package/src/libs/crud-pro/utils/MessageParseUtils.ts +33 -0
  409. package/src/libs/crud-pro/utils/MixinUtils.ts +285 -0
  410. package/src/libs/crud-pro/utils/ModelUtils.ts +55 -0
  411. package/src/libs/crud-pro/utils/MultiKeyMap.ts +72 -0
  412. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +29 -0
  413. package/src/libs/crud-pro/utils/TypeUtils.ts +188 -0
  414. package/src/libs/crud-pro/utils/ValidateUtils.ts +165 -0
  415. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +20 -0
  416. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +22 -0
  417. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +22 -0
  418. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +26 -0
  419. package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +26 -0
  420. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +11 -0
  421. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +11 -0
  422. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +129 -0
  423. package/src/libs/global-config/global-config.ts +109 -0
  424. package/src/libs/utils/base64.ts +47 -0
  425. package/src/libs/utils/common-dto.ts +52 -0
  426. package/src/libs/utils/crypto-utils.ts +50 -0
  427. package/src/libs/utils/errorToString.ts +61 -0
  428. package/src/libs/utils/fatcms-request.ts +103 -0
  429. package/src/libs/utils/functions.ts +78 -0
  430. package/src/libs/utils/ordernum-utils.ts +14 -0
  431. package/src/libs/utils/parseConfig.ts +54 -0
  432. package/src/libs/utils/parseCreateSql.ts +91 -0
  433. package/src/libs/utils/render-utils.ts +184 -0
  434. package/src/middleware/forbidden.middleware.ts +52 -0
  435. package/src/middleware/global.middleware.ts +293 -0
  436. package/src/middleware/permission.middleware.ts +80 -0
  437. package/src/middleware/rediscache.middleware.ts +91 -0
  438. package/src/middleware/redislock.middleware.ts +83 -0
  439. package/src/middleware/tx.middleware.ts +30 -0
  440. package/src/models/AsyncTaskModel.ts +85 -0
  441. package/src/models/RedisKeys.ts +16 -0
  442. package/src/models/SystemEntities.ts +125 -0
  443. package/src/models/SystemPerm.ts +105 -0
  444. package/src/models/SystemTables.ts +27 -0
  445. package/src/models/bizmodels.ts +123 -0
  446. package/src/models/contextLogger.ts +132 -0
  447. package/src/models/devops.ts +17 -0
  448. package/src/models/userSession.ts +217 -0
  449. package/src/schedule/anonymousContext.ts +73 -0
  450. package/src/schedule/index.ts +12 -0
  451. package/src/schedule/runSchedule.ts +82 -0
  452. package/src/schedule/scheduleNames.ts +21 -0
  453. package/src/service/AuthService.ts +284 -0
  454. package/src/service/EnumInfoService.ts +130 -0
  455. package/src/service/FileCenterService.ts +395 -0
  456. package/src/service/SysConfigService.ts +37 -0
  457. package/src/service/UserAccountService.ts +107 -0
  458. package/src/service/UserSessionService.ts +161 -0
  459. package/src/service/VisitStatService.ts +166 -0
  460. package/src/service/WorkbenchService.ts +220 -0
  461. package/src/service/anyapi/AnyApiSandboxService.ts +121 -0
  462. package/src/service/anyapi/AnyApiService.ts +186 -0
  463. package/src/service/asyncTask/AsyncTaskRunnerService.ts +325 -0
  464. package/src/service/asyncTask/AsyncTaskService.ts +21 -0
  465. package/src/service/asyncTask/handler/ExcelInfoModel.ts +11 -0
  466. package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +245 -0
  467. package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +159 -0
  468. package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +159 -0
  469. package/src/service/base/ApiBaseService.ts +42 -0
  470. package/src/service/base/ApiRateLimiter.ts +59 -0
  471. package/src/service/base/BaseService.ts +100 -0
  472. package/src/service/base/RedisCacheService.ts +45 -0
  473. package/src/service/crudstd/CrudStdActionService.ts +27 -0
  474. package/src/service/crudstd/CrudStdConstant.ts +62 -0
  475. package/src/service/crudstd/CrudStdRelationService.ts +118 -0
  476. package/src/service/crudstd/CrudStdService.ts +420 -0
  477. package/src/service/curd/CrudProQuick.ts +172 -0
  478. package/src/service/curd/CurdMixByAccountService.ts +89 -0
  479. package/src/service/curd/CurdMixByDictService.ts +114 -0
  480. package/src/service/curd/CurdMixByLinkToCustomService.ts +219 -0
  481. package/src/service/curd/CurdMixBySysConfigService.ts +78 -0
  482. package/src/service/curd/CurdMixByWorkbenchService.ts +71 -0
  483. package/src/service/curd/CurdMixService.ts +97 -0
  484. package/src/service/curd/CurdMixUtils.ts +316 -0
  485. package/src/service/curd/CurdProService.ts +231 -0
  486. package/src/service/curd/fixCfgModel.ts +120 -0
  487. package/src/service/proxyapi/ProxyApiLoadService.ts +174 -0
  488. package/src/service/proxyapi/ProxyApiService.ts +298 -0
  489. package/src/service/proxyapi/ProxyApiUtils.ts +32 -0
  490. package/src/service/proxyapi/RouteHandler.ts +8 -0
  491. package/src/service/proxyapi/RouteTrie.ts +74 -0
  492. package/src/service/proxyapi/WeightedRandom.ts +37 -0
  493. package/src/service/proxyapi/WeightedRoundRobin.ts +44 -0
  494. package/src/views/404_app.html +31 -0
  495. package/src/views/404_workbench.html +34 -0
  496. package/src/views/static/favicon.ico +0 -0
  497. package/tsconfig.json +32 -32
@@ -0,0 +1,91 @@
1
+ function isChineseChar(char: string): boolean {
2
+ const reg = /[\u4e00-\u9fff]/;
3
+ return reg.test(char);
4
+ }
5
+
6
+ function isLetterOrNumber(char) {
7
+ const reg = /^[a-zA-Z0-9]$/;
8
+ return reg.test(char);
9
+ }
10
+ function isTitleValidChar(c: string) {
11
+ return isChineseChar(c) || isLetterOrNumber(c) || c === ' ';
12
+ }
13
+
14
+ /**
15
+ * 移除引号
16
+ * @param s
17
+ */
18
+ function parseTableFieldTitleFromComment(s: string): string {
19
+ if (!s) {
20
+ return '';
21
+ }
22
+ s = s.trim();
23
+ s = s.replace(/'/gm, '');
24
+ const arr = [];
25
+ for (let i = 0; i < s.length; i++) {
26
+ const c = s.charAt(i);
27
+ if (isTitleValidChar(c)) {
28
+ arr.push(c);
29
+ } else {
30
+ break;
31
+ }
32
+ }
33
+ return arr.join('');
34
+ }
35
+
36
+ /**
37
+ * 从最后一行中提取表格的标题
38
+ * @param arr
39
+ */
40
+ function parseTableTitle(arr: string[]): string {
41
+ if (arr.length === 0) {
42
+ return '';
43
+ }
44
+
45
+ // 最后一行
46
+ const key = ' COMMENT=';
47
+ const lastStr = arr[arr.length - 1].toUpperCase();
48
+ const s = lastStr.indexOf(key);
49
+ if (s < 0) {
50
+ return '';
51
+ }
52
+ const c = lastStr.substring(s + key.length).trim();
53
+ return parseTableFieldTitleFromComment(c);
54
+ }
55
+
56
+ function parseCreateSqlToTitleMap(createSqlStr: string) {
57
+ if (!createSqlStr) {
58
+ return {
59
+ tableTitle: '',
60
+ fieldsTitleMap: {},
61
+ };
62
+ }
63
+ const titleMap = {};
64
+ const arr0 = createSqlStr.split('\n').map(s => {
65
+ return s.trim();
66
+ });
67
+
68
+ const tableTitle = parseTableTitle(arr0);
69
+
70
+ let arr = arr0.filter(s => {
71
+ return !(s.endsWith('(') || s.startsWith('('));
72
+ });
73
+ arr = arr.filter(s => {
74
+ return s.includes(' COMMENT ');
75
+ });
76
+
77
+ for (let i = 0; i < arr.length; i++) {
78
+ const arrElement = arr[i].split(' COMMENT ');
79
+ const e0 = arrElement[0];
80
+ const e1 = arrElement[1];
81
+ const keyArr = e0.split(' ');
82
+ const field = keyArr[0].replace(/`/gm, '');
83
+ titleMap[field] = parseTableFieldTitleFromComment(e1).trim();
84
+ }
85
+ return {
86
+ tableTitle, // 表格标题
87
+ fieldsTitleMap: titleMap, // 列标题
88
+ };
89
+ }
90
+
91
+ export { parseCreateSqlToTitleMap, parseTableFieldTitleFromComment };
@@ -0,0 +1,184 @@
1
+ import * as _ from 'lodash';
2
+ import * as moment from 'moment';
3
+ import {Context} from '@midwayjs/koa';
4
+ import {parseJsonObject} from "./functions";
5
+ import {getExtLocalLoaderPort} from "./fatcms-request";
6
+ import {TypeUtils} from "../crud-pro/utils/TypeUtils";
7
+
8
+ // const demo = {"schema":[
9
+ // {"title":"资源配置","name":"fileList","type":"array","properties":{"fileUrl":{"label":"文件URL","component":"Input","xProps":{"hasClear":true},"width":500}}}],
10
+ // "data":{"fileList":[{"settingKey":"n1iqmu8qnc_1","fileUrl":"aa"},{"settingKey":"n1iqmu8rml_2","fileUrl":"aa"}]
11
+ // }}
12
+
13
+
14
+ interface IFileElement {
15
+ fileUrl: string;
16
+ fileType?: string;
17
+ isModule?: boolean;
18
+ }
19
+
20
+ interface IRenderUtilsProps {
21
+ ctx: Context;
22
+ package_assets: any;
23
+ workbenchInfo: any;
24
+ userInfo?: any;
25
+ appInfo?: any;
26
+ fatcmscsrftoken: string;
27
+ }
28
+
29
+ function parseCookie(cookieStr:string) : any {
30
+ const cookies = {};
31
+
32
+ if (!cookieStr) {
33
+ return cookies;
34
+ }
35
+
36
+ // 分割每个 cookie 项
37
+ const cookieItems = cookieStr.split(';');
38
+
39
+ for (const item of cookieItems) {
40
+ // 去除空白字符
41
+ const trimmedItem = item.trim();
42
+ if (!trimmedItem) {
43
+ continue;
44
+ }
45
+
46
+ // 找到第一个等号的位置
47
+ const eqIndex = trimmedItem.indexOf('=');
48
+ if (eqIndex === -1) {
49
+ continue;
50
+ }
51
+
52
+ // 提取 key 和 value
53
+ const key = trimmedItem.substring(0, eqIndex).trim();
54
+ const value = trimmedItem.substring(eqIndex + 1).trim();
55
+
56
+ // 处理可能的引号
57
+ if (value.startsWith('"') && value.endsWith('"')) {
58
+ cookies[key] = value.slice(1, -1);
59
+ } else {
60
+ cookies[key] = value;
61
+ }
62
+ }
63
+
64
+ return cookies;
65
+ }
66
+
67
+
68
+ class RenderUtils {
69
+ private readonly ctx: Context;
70
+ private readonly fileList: IFileElement[];
71
+ private readonly workbenchInfo: any;
72
+ private readonly userInfo: any;
73
+ private readonly appInfo: any;
74
+ private readonly fatcmscsrftoken: string;
75
+
76
+ constructor(props: IRenderUtilsProps) {
77
+ this.ctx = props.ctx;
78
+ this.workbenchInfo = props.workbenchInfo || {};
79
+ this.userInfo = props.userInfo || {};
80
+ this.appInfo = props.appInfo || {};
81
+ this.fatcmscsrftoken = props.fatcmscsrftoken;
82
+ const packageAssets = parseJsonObject(props.package_assets) || {};
83
+ const fileList = _.get(packageAssets, 'data.fileList');
84
+ if (Array.isArray(fileList)) {
85
+ this.fileList = fileList.filter((f)=> {
86
+ return f && f.fileUrl && typeof f.fileUrl === 'string' && f.fileUrl.length > 5; // 至少五个字符。
87
+ });
88
+ } else {
89
+ this.fileList = [];
90
+ const time = moment().format('YYYY-MM-DD HH:mm:ss.SSS');
91
+ console.info(time + ' 解析fileList为空==>' + JSON.stringify({
92
+ workbench_code: this.workbenchInfo?.workbench_code,
93
+ app_code: this.appInfo?.app_code,
94
+ }))
95
+ }
96
+ }
97
+
98
+ renderCsrfToken() {
99
+ return `<script>window.__fatcmscsrftoken = "${this.fatcmscsrftoken}";</script>`;
100
+ }
101
+
102
+ renderUserInfo() {
103
+ return `<script>window.__user_info = ${JSON.stringify(this.userInfo)} </script>`;
104
+ }
105
+
106
+ renderWorkbenchInfo() {
107
+ const infoPick = _.pick(this.workbenchInfo, [
108
+ 'id', 'workbench_code', 'workbench_name', 'workbench_domain', 'workbench_desc', 'config_type', 'config_content'
109
+ ]);
110
+ return `<script>window.__workbench_info = ${JSON.stringify(infoPick)}</script>`;
111
+ }
112
+
113
+ renderAppInfo() {
114
+ const infoPick = _.pick(this.appInfo, [
115
+ 'id', 'app_code', 'app_name', 'app_type', 'app_desc', 'config_type', 'config_content'
116
+ ]);
117
+ return `<script>window.__app_info = ${JSON.stringify(infoPick)}</script>`;
118
+ }
119
+
120
+ renderCookieInfo(keys: string) {
121
+ try {
122
+ const cookies = parseCookie(this.ctx.headers?.cookie)
123
+ const cookieObj = {};
124
+ if (typeof keys === 'string') {
125
+ const keyArr = keys.split(',');
126
+ for (let i = 0; i < keyArr.length; i++) {
127
+ const keyName = keyArr[i];
128
+ cookieObj[keyName] = cookies[keyName];
129
+ }
130
+ }
131
+ return `<script>window.__cookie_info = ${JSON.stringify(cookieObj)}</script>`;
132
+ } catch (e) {
133
+ return `<script>window.__cookie_info_error = ${e}; </script>`;
134
+ }
135
+
136
+ }
137
+
138
+
139
+ renderJsAssets() {
140
+ const fileList = this.fileList.filter((s) => {
141
+ return s.fileType === 'js' || s.fileUrl.endsWith('.js');
142
+ });
143
+ const arr = fileList.map(f => {
144
+ if (f.isModule) {
145
+ return `<script type="module" crossorigin src="${f.fileUrl}" ></script>`
146
+ }
147
+ return `<script src="${f.fileUrl}" ></script>`
148
+ });
149
+ return arr.join('\n');
150
+ }
151
+
152
+ renderCssAssets() {
153
+ const fileList = this.fileList.filter((s) => {
154
+ return s.fileType === 'css' || s.fileUrl.endsWith('.css');
155
+ });
156
+ const fileUrlList = fileList.map(f => {
157
+ return f.fileUrl;
158
+ });
159
+
160
+ const arr = fileUrlList.map((url) => {
161
+ return `<link href="${url}" rel="stylesheet" />`;
162
+ });
163
+ return arr.join('\n');
164
+ }
165
+
166
+
167
+
168
+ renderExtLocalLoaderPortByDevHeader(){
169
+ const loaderPort = getExtLocalLoaderPort(this.ctx);
170
+ if (loaderPort && TypeUtils.isNumeric(loaderPort)) {
171
+ return `<script>window.__local_loader_port_from_dev_header = ${loaderPort}</script>`;
172
+ }
173
+ return '';
174
+ }
175
+
176
+ }
177
+
178
+ function createRenderUtils(props: IRenderUtilsProps) {
179
+ return new RenderUtils(props)
180
+ }
181
+
182
+ export {
183
+ createRenderUtils
184
+ }
@@ -0,0 +1,52 @@
1
+ import { Middleware, IMiddleware } from '@midwayjs/core';
2
+ import { NextFunction, Context } from '@midwayjs/koa';
3
+
4
+ // 一些爬虫/漏洞分析工具会来请求这玩意。
5
+ const blackEqualList = ['/config.json', '/backend/.env', '/application.yml', '/db.ini', '/.well-known/security.txt'];
6
+
7
+ const blackPrefixList = ['/.aws/', '/.git/', '/.svn/', '/.env/', '/src/', '/var/logs/', '/var/log/', '/cgi-bin/', '/php-cgi/'];
8
+
9
+ /**
10
+ * 针对一些路径禁止访问。避免一些爬虫抓取网站内容,实际上这里枚举的路径,本身就是不存在的。只是为了提前拦截,为了服务器性能考虑。
11
+ */
12
+ @Middleware()
13
+ export class ForbiddenMiddleware implements IMiddleware<Context, NextFunction> {
14
+ match(ctx: Context): boolean {
15
+ const path = ctx.path;
16
+ if (path === '/') {
17
+ return false;
18
+ }
19
+
20
+ if (path.startsWith('/ns/') || path.startsWith('/pages/')) {
21
+ return false;
22
+ }
23
+
24
+ for (let i = 0; i < blackEqualList.length; i++) {
25
+ const backlistElement = blackEqualList[i];
26
+ if (path === backlistElement) {
27
+ return true;
28
+ }
29
+ }
30
+
31
+ for (let i = 0; i < blackPrefixList.length; i++) {
32
+ const blackPrefix = blackPrefixList[i];
33
+ if (path.startsWith(blackPrefix)) {
34
+ return true;
35
+ }
36
+ }
37
+
38
+ return !!(path.includes('/wp-includes/') || path.includes('/wp-admin/') || path.includes('/wp-content/') || path.endsWith('.php') || path.endsWith('/.git/config'));
39
+ }
40
+
41
+ resolve() {
42
+ return async (ctx: Context, next: NextFunction) => {
43
+ ctx.set({ 'content-type': 'text/html; charset=utf-8' });
44
+ ctx.status = 404;
45
+ ctx.body = '404!404!404!重要的事情说三遍!';
46
+ };
47
+ }
48
+
49
+ static getName(): string {
50
+ return 'ForbiddenMiddleware';
51
+ }
52
+ }
@@ -0,0 +1,293 @@
1
+ import { Middleware, IMiddleware } from '@midwayjs/core';
2
+ import { NextFunction, Context } from '@midwayjs/koa';
3
+ import * as _ from 'lodash';
4
+ import { Transaction } from '@/libs/crud-pro/models/Transaction';
5
+ import { UserSessionService } from '@/service/UserSessionService';
6
+ import { WorkbenchService } from '@/service/WorkbenchService';
7
+ import { ISessionInfo, UserSessionInfo } from '@/models/userSession';
8
+ import { ICommonResult, CommonResult } from '@/libs/utils/common-dto';
9
+ import { isEnableDebug, isEnableSuperAdmin } from '@/libs/utils/fatcms-request';
10
+ import { ContextLogger } from '@/models/contextLogger';
11
+ import { Stream } from 'node:stream';
12
+ import { VisitStatService } from '@/service/VisitStatService';
13
+
14
+ function isFunction(fun: any): boolean {
15
+ return typeof fun === 'function';
16
+ }
17
+
18
+ function isObject(obj: any): boolean {
19
+ return obj && typeof obj === 'object';
20
+ }
21
+
22
+ function isArrayBuffer(obj: any): boolean {
23
+ if (!obj) {
24
+ return false;
25
+ }
26
+ return obj instanceof ArrayBuffer || Object.prototype.toString.call(obj) === '[object ArrayBuffer]';
27
+ }
28
+
29
+ function isBlob(obj: any): boolean {
30
+ return obj?.constructor?.name === 'Blob';
31
+ }
32
+
33
+ function isStream(obj: any): boolean {
34
+ return obj && obj instanceof Stream;
35
+ }
36
+
37
+ async function getUserSessionService(ctx: Context): Promise<UserSessionService> {
38
+ return ctx.requestContext.getAsync(UserSessionService);
39
+ }
40
+
41
+ async function getWorkbenchService(ctx: Context): Promise<WorkbenchService> {
42
+ return ctx.requestContext.getAsync(WorkbenchService);
43
+ }
44
+
45
+ async function getVisitStatService(ctx: Context): Promise<VisitStatService> {
46
+ return ctx.requestContext.getAsync(VisitStatService);
47
+ }
48
+
49
+ /**
50
+ * 专门对ExecuteSqlContext对象进行处理
51
+ * @param res
52
+ */
53
+ function handleExecuteSqlContext(res: any): ICommonResult {
54
+ // ExecuteSqlContext
55
+ if (res && isFunction(res.getResMessage) && isFunction(res.getResModel)) {
56
+ const message = res.getResMessage();
57
+ return { success: true, message: message, data: res.getResModel() };
58
+ }
59
+ return res;
60
+ }
61
+
62
+ /**
63
+ * 处理空数据
64
+ * @param res
65
+ */
66
+ function handleNullRes(res: any): ICommonResult {
67
+ if (res === null || typeof res === 'undefined') {
68
+ return { success: false, message: '接口没有返回任何数据', data: null };
69
+ }
70
+ return res;
71
+ }
72
+
73
+ /**
74
+ * 处理普通数组数据
75
+ * @param res
76
+ */
77
+ function handleArrayRes(res: any): ICommonResult {
78
+ if (Array.isArray(res) && res.length) {
79
+ return { success: true, data: res };
80
+ }
81
+ return res;
82
+ }
83
+
84
+ function addDebugInfoFromContext(debugInfo: any, ctx: Context): void {
85
+ const userSession: UserSessionInfo = ctx.userSession;
86
+ const contextLogger: ContextLogger = ctx.contextLogger;
87
+ if (isObject(userSession)) {
88
+ const sessionInfo = userSession.getSessionInfo();
89
+ _.set(debugInfo, 'sessionInfo', sessionInfo);
90
+ }
91
+ if (isObject(contextLogger)) {
92
+ _.set(debugInfo, 'logList', contextLogger.getLogList());
93
+ }
94
+ }
95
+
96
+ /**
97
+ * 处理调试信息
98
+ * @param beforeRes 上一个输出
99
+ * @param ctx
100
+ * @param originRes 最原始的输出
101
+ */
102
+ function handleDebugRes(beforeRes: any, ctx: Context, originRes: any): ICommonResult {
103
+ const isDebug = isEnableDebug(ctx);
104
+
105
+ if (!isDebug) {
106
+ // 没有开启debug模式
107
+ if (beforeRes && beforeRes.debugInfo) {
108
+ delete beforeRes.debugInfo;
109
+ }
110
+ return beforeRes;
111
+ }
112
+
113
+ // 开启了debug模式
114
+ const debugInfo = {};
115
+
116
+ addDebugInfoFromContext(debugInfo, ctx);
117
+
118
+ //debugInfo3. 响应中本身就有debugInfo
119
+ if (isObject(originRes)) {
120
+ if (typeof originRes.debugInfo === 'string') {
121
+ _.set(debugInfo, 'debugInfo', originRes.debugInfo);
122
+ }
123
+ if (isObject(beforeRes.debugInfo)) {
124
+ Object.assign(debugInfo, originRes.debugInfo);
125
+ }
126
+
127
+ if (isFunction(originRes.getReqModel)) {
128
+ _.set(debugInfo, 'reqMode', originRes.getReqModel());
129
+ }
130
+ if (isObject(originRes.cfgModel)) {
131
+ _.set(debugInfo, 'cfgMode', originRes.cfgModel);
132
+ }
133
+ }
134
+
135
+ // debugInfo处理完毕
136
+ const nextRes: any = {};
137
+ if (isObject(beforeRes)) {
138
+ Object.assign(nextRes, beforeRes);
139
+ }
140
+ nextRes.debugInfo = debugInfo;
141
+ return nextRes as ICommonResult;
142
+ }
143
+
144
+ /**
145
+ * 检查是否是超级管理员
146
+ * @param ctx
147
+ * @param sessionInfo
148
+ */
149
+ function checkIsSuperAdmin(ctx: Context, sessionInfo: ISessionInfo): boolean {
150
+ if (!sessionInfo || !sessionInfo.loginName) {
151
+ return false;
152
+ }
153
+
154
+ if (!isEnableSuperAdmin(ctx)) {
155
+ return false;
156
+ }
157
+
158
+ const currentLoginName = sessionInfo.loginName;
159
+ const superAdminList = ctx.app.getConfig('superAdminList');
160
+
161
+ if (Array.isArray(superAdminList)) {
162
+ for (let i = 0; i < superAdminList.length; i++) {
163
+ const element = superAdminList[i];
164
+ const login_name = _.get(element, 'login_name');
165
+ if (login_name && login_name === currentLoginName) {
166
+ return true;
167
+ }
168
+ }
169
+ }
170
+ return false;
171
+ }
172
+
173
+ /**
174
+ * 处理调试错误
175
+ * @param e
176
+ * @param ctx
177
+ * @returns
178
+ */
179
+ function handleDebugError(e: any, ctx: Context): ICommonResult {
180
+ ctx.logger.error('GlobalMiddleware', e);
181
+
182
+ let errorStack = null;
183
+ let errorCode = null;
184
+ let errorMessage = '' + e;
185
+
186
+ if (isObject(e)) {
187
+ if (e.message) {
188
+ errorMessage = e.message;
189
+ }
190
+ if (e.code) {
191
+ errorCode = e.code;
192
+ }
193
+ errorStack = e.stack;
194
+ }
195
+
196
+ const res = CommonResult.errorRes(errorMessage, errorCode);
197
+ if (isEnableDebug(ctx)) {
198
+ const debugInfo = { errorStack };
199
+ addDebugInfoFromContext(debugInfo, ctx);
200
+ res.debugInfo = debugInfo;
201
+ }
202
+
203
+ return res;
204
+ }
205
+
206
+ /**
207
+ * 数据埋点
208
+ * @param ctx
209
+ */
210
+ async function trackRequest(ctx: Context) {
211
+ try {
212
+ const visitStatService = await getVisitStatService(ctx);
213
+ await visitStatService.trackRequest(ctx.path, 'path');
214
+ } catch (e) {
215
+ console.error('trackRequestError', e);
216
+ }
217
+ }
218
+
219
+ /**
220
+ * 这些路径不需要配置用户信息等操作
221
+ */
222
+ const excludePathPrefix = ['/ns/static/', '/ns/api/helpers'];
223
+
224
+ /**
225
+ * 全局中间件
226
+ */
227
+ @Middleware()
228
+ export class GlobalMiddleware implements IMiddleware<Context, NextFunction> {
229
+ match(ctx: Context): boolean {
230
+ const path: string = ctx.path;
231
+ for (let i = 0; i < excludePathPrefix.length; i++) {
232
+ const excludePathPrefix1 = excludePathPrefix[i];
233
+ if (path.startsWith(excludePathPrefix1)) {
234
+ return false;
235
+ }
236
+ }
237
+ return true;
238
+ }
239
+
240
+ resolve() {
241
+ return async (ctx: Context, next: NextFunction) => {
242
+ ctx.contextLogger = new ContextLogger(ctx);
243
+ ctx.transaction = new Transaction();
244
+
245
+ try {
246
+ // 支持的站点
247
+ const workbenchService = await getWorkbenchService(ctx);
248
+ const isSupportTheHost = await workbenchService.isSupportCurrentHostForForMiddleware();
249
+ if (isSupportTheHost !== true) {
250
+ return isSupportTheHost;
251
+ }
252
+
253
+ const sessionService = await getUserSessionService(ctx);
254
+ const sessionInfo = await sessionService.getCurrentUserSessionForMiddleware();
255
+ const isSuperAdmin = checkIsSuperAdmin(ctx, sessionInfo);
256
+
257
+ ctx.userSession = new UserSessionInfo(sessionInfo, isSuperAdmin);
258
+ ctx.workbenchInfo = await workbenchService.getCurrentHostWorkbenchInfo();
259
+
260
+ // 数据埋点
261
+ await trackRequest(ctx);
262
+
263
+ const res0 = await next();
264
+
265
+ // 基本数据类型:需要搞成字符串
266
+ if (['bigint', 'symbol'].includes(typeof res0)) {
267
+ return res0.toString();
268
+ }
269
+
270
+ // 基本数据类型: 交给KOA处理的
271
+ if (!res0 || ['string', 'number', 'boolean'].includes(typeof res0) || Buffer.isBuffer(res0) || isArrayBuffer(res0) || isStream(res0) || isBlob(res0)) {
272
+ return res0;
273
+ }
274
+
275
+ // 其他:普通的JSON数据
276
+ let res = handleExecuteSqlContext(res0);
277
+ res = handleNullRes(res);
278
+ res = handleArrayRes(res);
279
+ res = handleDebugRes(res, ctx, res0);
280
+
281
+ return res;
282
+ } catch (e) {
283
+ return handleDebugError(e, ctx);
284
+ } finally {
285
+ await ctx.transaction.releaseTx();
286
+ }
287
+ };
288
+ }
289
+
290
+ static getName(): string {
291
+ return 'GlobalMiddleware';
292
+ }
293
+ }
@@ -0,0 +1,80 @@
1
+ import { NextFunction, Context } from '@midwayjs/koa';
2
+ import { Exceptions } from '@/libs/crud-pro/exceptions';
3
+
4
+ function checkPermission(codeList: string | string[]) {
5
+ return async (ctx: Context, next: NextFunction) => {
6
+ const userSession = ctx.userSession;
7
+
8
+ // 只有登录用户才会有功能点权限,所以必须登录
9
+ if (!userSession.isLogin()) {
10
+ return {
11
+ success: false,
12
+ message: '用户未登录, 请先登录',
13
+ code: Exceptions.NOT_LOGIN,
14
+ };
15
+ }
16
+
17
+ // 查询当前用户是否用此功能点的权限
18
+ const hasPermission = userSession.hasAnyPermission(codeList);
19
+ if (!hasPermission) {
20
+ let message: string;
21
+ const loginName = userSession.getSessionInfo().loginName;
22
+ if (loginName === 'devopsviewer') {
23
+ message = '开放体验账号不支持这些操作:新增、修改、删除、上传';
24
+ } else {
25
+ message = '缺少权限: ' + JSON.stringify(codeList);
26
+ }
27
+
28
+ return {
29
+ success: false,
30
+ message: message,
31
+ code: Exceptions.NO_AUTH,
32
+ };
33
+ }
34
+
35
+ await next();
36
+ };
37
+ }
38
+
39
+ function checkRole(codeList: string | string[]) {
40
+ return async (ctx: Context, next: NextFunction) => {
41
+ const userSession = ctx.userSession;
42
+
43
+ // 只有登录用户才会有功能点权限,所以必须登录
44
+ if (!userSession.isLogin()) {
45
+ return {
46
+ success: false,
47
+ message: '用户未登录, 请先登录',
48
+ code: Exceptions.NOT_LOGIN,
49
+ };
50
+ }
51
+
52
+ // 查询当前用户是否用此功能点的权限
53
+ const hasRole = userSession.hasAnyRole(codeList);
54
+ if (!hasRole) {
55
+ return {
56
+ success: false,
57
+ message: '缺少角色权限: ' + JSON.stringify(codeList),
58
+ code: Exceptions.NO_AUTH,
59
+ };
60
+ }
61
+
62
+ await next();
63
+ };
64
+ }
65
+
66
+ function checkLogin() {
67
+ return async (ctx: Context, next: NextFunction) => {
68
+ const userSession = ctx.userSession;
69
+ if (!userSession.isLogin()) {
70
+ return {
71
+ success: false,
72
+ message: '用户未登录, 请先登录',
73
+ code: Exceptions.NOT_LOGIN,
74
+ };
75
+ }
76
+ await next();
77
+ };
78
+ }
79
+
80
+ export { checkPermission, checkLogin, checkRole };