midway-fatcms 0.0.1-beta.25 → 0.0.1-beta.28
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.
- package/dist/controller/home.controller.js +2 -1
- package/dist/controller/render/AppRenderController.js +2 -1
- package/dist/models/bizmodels.d.ts +1 -0
- package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +1 -1
- package/dist/service/crudstd/CrudStdService.d.ts +0 -6
- package/dist/service/crudstd/CrudStdService.js +13 -33
- package/package.json +1 -5
- package/src/config/config.default.ts +0 -207
- package/src/config/seed/aeskey.txt +0 -1
- package/src/config/utils.ts +0 -22
- package/src/configuration.ts +0 -109
- package/src/controller/base/BaseApiController.ts +0 -170
- package/src/controller/gateway/AnyApiGatewayController.ts +0 -33
- package/src/controller/gateway/AsyncTaskController.ts +0 -157
- package/src/controller/gateway/CrudMtdGatewayController.ts +0 -111
- package/src/controller/gateway/CrudStdGatewayController.ts +0 -101
- package/src/controller/gateway/DocGatewayController.ts +0 -173
- package/src/controller/gateway/FileController.ts +0 -109
- package/src/controller/gateway/ProxyApiGatewayController.ts +0 -47
- package/src/controller/gateway/PublicApiController.ts +0 -142
- package/src/controller/gateway/StaticController.ts +0 -298
- package/src/controller/helpers.controller.ts +0 -161
- package/src/controller/home.controller.ts +0 -64
- package/src/controller/manage/AnyApiMangeApi.ts +0 -66
- package/src/controller/manage/AppLogMangeApi.ts +0 -53
- package/src/controller/manage/AppMangeApi.ts +0 -53
- package/src/controller/manage/AppPageMangeApi.ts +0 -52
- package/src/controller/manage/AppSchemaHistoryApi.ts +0 -49
- package/src/controller/manage/CrudMethodsMangeApi.ts +0 -49
- package/src/controller/manage/CrudStandardDesignApi.ts +0 -346
- package/src/controller/manage/DataDictManageApi.ts +0 -78
- package/src/controller/manage/DeployManageApi.ts +0 -175
- package/src/controller/manage/DocLibManageApi.ts +0 -69
- package/src/controller/manage/DocManageApi.ts +0 -99
- package/src/controller/manage/FileManageApi.ts +0 -45
- package/src/controller/manage/LowCodeTplManageApi.ts +0 -52
- package/src/controller/manage/MenuManageApi.ts +0 -58
- package/src/controller/manage/ProxyApiMangeApi.ts +0 -52
- package/src/controller/manage/SuperAdminManageApi.ts +0 -139
- package/src/controller/manage/SysConfigMangeApi.ts +0 -95
- package/src/controller/manage/SystemInfoManageApi.ts +0 -53
- package/src/controller/manage/UserAccountManageApi.ts +0 -94
- package/src/controller/manage/WorkbenchMangeApi.ts +0 -72
- package/src/controller/myinfo/AuthController.ts +0 -108
- package/src/controller/myinfo/MyInfoController.ts +0 -32
- package/src/controller/render/AppRenderController.ts +0 -79
- package/src/controller/test.controller.ts +0 -37
- package/src/filter/default.filter.ts +0 -13
- package/src/filter/notfound.filter.ts +0 -10
- package/src/index.ts +0 -106
- package/src/interface.ts +0 -31
- package/src/libs/crud-pro/CrudPro.ts +0 -165
- package/src/libs/crud-pro/defaultConfigs.ts +0 -15
- package/src/libs/crud-pro/exceptions.ts +0 -124
- package/src/libs/crud-pro/interfaces.ts +0 -190
- package/src/libs/crud-pro/models/ExecuteContext.ts +0 -120
- package/src/libs/crud-pro/models/ExecuteContextFunc.ts +0 -96
- package/src/libs/crud-pro/models/FuncContext.ts +0 -21
- package/src/libs/crud-pro/models/RequestCfgModel.ts +0 -141
- package/src/libs/crud-pro/models/RequestModel.ts +0 -141
- package/src/libs/crud-pro/models/ResModel.ts +0 -19
- package/src/libs/crud-pro/models/ServiceHub.ts +0 -32
- package/src/libs/crud-pro/models/SqlCfgModel.ts +0 -52
- package/src/libs/crud-pro/models/SqlSegArg.ts +0 -13
- package/src/libs/crud-pro/models/Transaction.ts +0 -73
- package/src/libs/crud-pro/models/TransactionMySQL.ts +0 -79
- package/src/libs/crud-pro/models/TransactionPostgres.ts +0 -91
- package/src/libs/crud-pro/models/TransactionSqlServer.ts +0 -102
- package/src/libs/crud-pro/models/keys.ts +0 -159
- package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +0 -83
- package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +0 -128
- package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +0 -262
- package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +0 -60
- package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +0 -180
- package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +0 -354
- package/src/libs/crud-pro/services/CrudProGenSqlService.ts +0 -185
- package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +0 -393
- package/src/libs/crud-pro/services/CrudProServiceBase.ts +0 -94
- package/src/libs/crud-pro/services/CrudProTableMetaService.ts +0 -86
- package/src/libs/crud-pro/services/CurdProServiceHub.ts +0 -92
- package/src/libs/crud-pro/sql.txt +0 -120
- package/src/libs/crud-pro/utils/CompareUtils.ts +0 -23
- package/src/libs/crud-pro/utils/DatabaseName.ts +0 -60
- package/src/libs/crud-pro/utils/DateTimeUtils.ts +0 -20
- package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +0 -64
- package/src/libs/crud-pro/utils/MessageParseUtils.ts +0 -33
- package/src/libs/crud-pro/utils/MixinUtils.ts +0 -285
- package/src/libs/crud-pro/utils/ModelUtils.ts +0 -55
- package/src/libs/crud-pro/utils/MultiKeyMap.ts +0 -72
- package/src/libs/crud-pro/utils/SqlFuncUtils.ts +0 -29
- package/src/libs/crud-pro/utils/TypeUtils.ts +0 -188
- package/src/libs/crud-pro/utils/ValidateUtils.ts +0 -165
- package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +0 -20
- package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +0 -22
- package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +0 -22
- package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +0 -26
- package/src/libs/crud-pro/utils/sqlConvert/convertMix.ts +0 -26
- package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +0 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +0 -11
- package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +0 -129
- package/src/libs/global-config/global-config.ts +0 -78
- package/src/libs/utils/common-dto.ts +0 -52
- package/src/libs/utils/crypto-utils.ts +0 -50
- package/src/libs/utils/errorToString.ts +0 -61
- package/src/libs/utils/fatcms-request.ts +0 -103
- package/src/libs/utils/functions.ts +0 -73
- package/src/libs/utils/ordernum-utils.ts +0 -14
- package/src/libs/utils/parseConfig.ts +0 -54
- package/src/libs/utils/parseCreateSql.ts +0 -91
- package/src/libs/utils/render-utils.ts +0 -184
- package/src/middleware/forbidden.middleware.ts +0 -52
- package/src/middleware/global.middleware.ts +0 -280
- package/src/middleware/permission.middleware.ts +0 -80
- package/src/middleware/tx.middleware.ts +0 -30
- package/src/models/AsyncTaskModel.ts +0 -82
- package/src/models/RedisKeys.ts +0 -13
- package/src/models/SystemEntities.ts +0 -115
- package/src/models/SystemPerm.ts +0 -105
- package/src/models/SystemTables.ts +0 -27
- package/src/models/bizmodels.ts +0 -120
- package/src/models/contextLogger.ts +0 -132
- package/src/models/devops.ts +0 -17
- package/src/models/userSession.ts +0 -216
- package/src/schedule/anonymousContext.ts +0 -73
- package/src/schedule/index.ts +0 -12
- package/src/schedule/runSchedule.ts +0 -82
- package/src/schedule/scheduleNames.ts +0 -21
- package/src/service/AuthService.ts +0 -272
- package/src/service/EnumInfoService.ts +0 -130
- package/src/service/FileCenterService.ts +0 -395
- package/src/service/SysConfigService.ts +0 -37
- package/src/service/UserAccountService.ts +0 -107
- package/src/service/UserSessionService.ts +0 -78
- package/src/service/VisitStatService.ts +0 -166
- package/src/service/WorkbenchService.ts +0 -165
- package/src/service/anyapi/AnyApiSandboxService.ts +0 -121
- package/src/service/anyapi/AnyApiService.ts +0 -186
- package/src/service/asyncTask/AsyncTaskRunnerService.ts +0 -266
- package/src/service/asyncTask/AsyncTaskService.ts +0 -21
- package/src/service/asyncTask/handler/ExcelInfoModel.ts +0 -11
- package/src/service/asyncTask/handler/ExportExcelAsyncTaskHandler.ts +0 -245
- package/src/service/asyncTask/handler/ExportExcelByInnerHttpHandler.ts +0 -147
- package/src/service/asyncTask/handler/ExportExcelByStdCrudHandler.ts +0 -138
- package/src/service/base/ApiBaseService.ts +0 -42
- package/src/service/base/ApiRateLimiter.ts +0 -59
- package/src/service/base/BaseService.ts +0 -100
- package/src/service/base/RedisCacheService.ts +0 -38
- package/src/service/crudstd/CrudStdActionService.ts +0 -27
- package/src/service/crudstd/CrudStdConstant.ts +0 -62
- package/src/service/crudstd/CrudStdRelationService.ts +0 -78
- package/src/service/crudstd/CrudStdService.ts +0 -283
- package/src/service/curd/CrudProQuick.ts +0 -131
- package/src/service/curd/CurdMixByAccountService.ts +0 -90
- package/src/service/curd/CurdMixByDictService.ts +0 -114
- package/src/service/curd/CurdMixByLinkToCustomService.ts +0 -219
- package/src/service/curd/CurdMixBySysConfigService.ts +0 -78
- package/src/service/curd/CurdMixByWorkbenchService.ts +0 -71
- package/src/service/curd/CurdMixService.ts +0 -97
- package/src/service/curd/CurdMixUtils.ts +0 -311
- package/src/service/curd/CurdProService.ts +0 -229
- package/src/service/curd/fixCfgModel.ts +0 -139
- package/src/service/proxyapi/ProxyApiLoadService.ts +0 -174
- package/src/service/proxyapi/ProxyApiService.ts +0 -262
- package/src/service/proxyapi/ProxyApiUtils.ts +0 -32
- package/src/service/proxyapi/RouteHandler.ts +0 -8
- package/src/service/proxyapi/RouteTrie.ts +0 -74
- package/src/service/proxyapi/WeightedRandom.ts +0 -37
- package/src/service/proxyapi/WeightedRoundRobin.ts +0 -44
- package/src/views/404_app.html +0 -31
- package/src/views/404_workbench.html +0 -34
- package/src/views/static/favicon.ico +0 -0
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
import * as _ from 'lodash';
|
|
2
|
-
import { Config, Inject, Provide } from '@midwayjs/core';
|
|
3
|
-
import { CrudPro } from '@/libs/crud-pro/CrudPro';
|
|
4
|
-
import { Context } from '@midwayjs/koa';
|
|
5
|
-
import { IConnectionPool, ICrudProCfg, IRequestCfgModel, IRequestModel, ISqlCfgModel } from '@/libs/crud-pro/interfaces';
|
|
6
|
-
import { SqlCfgModel } from '@/libs/crud-pro/models/SqlCfgModel';
|
|
7
|
-
import { getConnectionPool as getMySQLConnectionPool } from '../../libs/crud-pro/utils/pool/MySQLUtils';
|
|
8
|
-
import { getConnectionPool as getPostgresConnectionPool } from '../../libs/crud-pro/utils/pool/PostgresUtils';
|
|
9
|
-
import { getConnectionPool as getSqlServerConnectionPool } from '../../libs/crud-pro/utils/pool/SqlServerUtils';
|
|
10
|
-
import { SqlDbType } from '@/libs/crud-pro/models/keys';
|
|
11
|
-
import { CommonException, Exceptions } from '@/libs/crud-pro/exceptions';
|
|
12
|
-
import { UserSessionInfo } from '@/models/userSession';
|
|
13
|
-
import { BaseExecuteContextFunc } from '@/libs/crud-pro/models/ExecuteContextFunc';
|
|
14
|
-
import { ExecuteContext, IExecuteContextHandler } from '@/libs/crud-pro/models/ExecuteContext';
|
|
15
|
-
import { RelatedType } from './CurdMixUtils';
|
|
16
|
-
import { BaseService } from '../base/BaseService';
|
|
17
|
-
import { IRequestCfgModel2, IVisitorExt } from '@/models/bizmodels';
|
|
18
|
-
import { IWorkbenchEntity } from '@/models/SystemEntities';
|
|
19
|
-
import { CrudProQuick } from '@/service/curd/CrudProQuick';
|
|
20
|
-
import { fixCfgModel } from './fixCfgModel';
|
|
21
|
-
import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
|
|
22
|
-
|
|
23
|
-
function toVisitor(ctx: Context): IVisitorExt {
|
|
24
|
-
const workbenchInfo: IWorkbenchEntity = ctx.workbenchInfo;
|
|
25
|
-
const userSession: UserSessionInfo = ctx.userSession;
|
|
26
|
-
if (!userSession || !userSession.isLogin()) {
|
|
27
|
-
return {
|
|
28
|
-
isLogin: false,
|
|
29
|
-
isSuperAdmin: false,
|
|
30
|
-
accountId: '0',
|
|
31
|
-
nickName: '匿名用户',
|
|
32
|
-
avatar: '',
|
|
33
|
-
accountType: '',
|
|
34
|
-
roleCodes: [],
|
|
35
|
-
functionCodes: [],
|
|
36
|
-
workbenchCode: workbenchInfo?.workbench_code || '',
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
const sessionInfo = userSession.getSessionInfo();
|
|
41
|
-
return {
|
|
42
|
-
isLogin: true,
|
|
43
|
-
isSuperAdmin: userSession.isSuperAdmin(),
|
|
44
|
-
accountId: sessionInfo.accountId,
|
|
45
|
-
nickName: sessionInfo.nickName,
|
|
46
|
-
avatar: sessionInfo.avatar,
|
|
47
|
-
accountType: sessionInfo.accountType,
|
|
48
|
-
roleCodes: sessionInfo.roleCodes || [],
|
|
49
|
-
functionCodes: sessionInfo.functionCodes || [],
|
|
50
|
-
workbenchCode: workbenchInfo?.workbench_code || '',
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
class MyContextFunc extends BaseExecuteContextFunc {
|
|
55
|
-
private readonly mysql2Config: any;
|
|
56
|
-
private readonly postgres2Config: any;
|
|
57
|
-
private readonly sqlserver2Config: any;
|
|
58
|
-
private readonly responseCfgHandlers: Record<string, IExecuteContextHandler>;
|
|
59
|
-
|
|
60
|
-
constructor(cfgMap: any, responseCfgHandlers: Record<string, IExecuteContextHandler>) {
|
|
61
|
-
super();
|
|
62
|
-
const { mysql2Config, postgres2Config, sqlserver2Config } = cfgMap;
|
|
63
|
-
this.mysql2Config = mysql2Config;
|
|
64
|
-
this.postgres2Config = postgres2Config;
|
|
65
|
-
this.sqlserver2Config = sqlserver2Config;
|
|
66
|
-
this.responseCfgHandlers = responseCfgHandlers;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
async getConnectionPool(sqlCfgModel: SqlCfgModel): Promise<IConnectionPool> {
|
|
70
|
-
if (!sqlCfgModel.sqlDatabase) {
|
|
71
|
-
console.error('[MyContextFunc]查询语句中未指定数据库', sqlCfgModel.executeSql);
|
|
72
|
-
throw new CommonException(Exceptions.DB_QUERY_PARAM_EMPTY, '查询语句中未指定数据库');
|
|
73
|
-
}
|
|
74
|
-
const dataBaseName = sqlCfgModel.sqlDatabase;
|
|
75
|
-
const sqlDbType = sqlCfgModel.sqlDbType;
|
|
76
|
-
|
|
77
|
-
if (sqlDbType === SqlDbType.postgres) {
|
|
78
|
-
const dbConfig = _.get(this.postgres2Config, dataBaseName);
|
|
79
|
-
if (!dbConfig) {
|
|
80
|
-
console.error('[MyContextFunc]postgres配置中不存在此数据库', JSON.stringify(sqlCfgModel));
|
|
81
|
-
throw new CommonException(Exceptions.DB_NOT_FOUND, 'postgres配置中不存在此数据库:' + dataBaseName);
|
|
82
|
-
}
|
|
83
|
-
return getPostgresConnectionPool(dataBaseName, dbConfig);
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
if (sqlDbType === SqlDbType.sqlserver) {
|
|
87
|
-
const dbConfig = _.get(this.sqlserver2Config, dataBaseName);
|
|
88
|
-
if (!dbConfig) {
|
|
89
|
-
console.error('[MyContextFunc]sqlserver配置中不存在此数据库', JSON.stringify(sqlCfgModel));
|
|
90
|
-
throw new CommonException(Exceptions.DB_NOT_FOUND, 'sqlserver配置中不存在此数据库:' + dataBaseName);
|
|
91
|
-
}
|
|
92
|
-
return getSqlServerConnectionPool(dataBaseName, dbConfig);
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
const dbConfig = _.get(this.mysql2Config, dataBaseName);
|
|
96
|
-
if (!dbConfig) {
|
|
97
|
-
console.error('[MyContextFunc]MySQL配置中不存在此数据库', JSON.stringify(sqlCfgModel));
|
|
98
|
-
throw new CommonException(Exceptions.DB_NOT_FOUND, 'MySQL配置中不存在此数据库:' + dataBaseName);
|
|
99
|
-
}
|
|
100
|
-
return getMySQLConnectionPool(dataBaseName, dbConfig);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
async afterExecuteSQLList(): Promise<any> {
|
|
104
|
-
const exeCtx = this.getExecuteContext();
|
|
105
|
-
const handlers = Object.values(this.responseCfgHandlers);
|
|
106
|
-
for (let i = 0; i < handlers.length; i++) {
|
|
107
|
-
const handler = handlers[i];
|
|
108
|
-
await handler.handleExecuteContextPrepare(exeCtx);
|
|
109
|
-
await handler.handleExecuteContext(exeCtx);
|
|
110
|
-
}
|
|
111
|
-
return null;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
/**
|
|
115
|
-
* 在执行之前可以根据业务需要修改需要执行的内容
|
|
116
|
-
* @param reqJson
|
|
117
|
-
* @param cfgJson
|
|
118
|
-
*/
|
|
119
|
-
async beforeExecuteSQLList(reqJson: IRequestModel, cfgJson: IRequestCfgModel): Promise<any> {
|
|
120
|
-
const { bizUpdateCfgModelForCrudPro } = GLOBAL_STATIC_CONFIG.getConfig();
|
|
121
|
-
if (typeof bizUpdateCfgModelForCrudPro === 'function') {
|
|
122
|
-
await bizUpdateCfgModelForCrudPro(reqJson, cfgJson);
|
|
123
|
-
}
|
|
124
|
-
return Promise.resolve();
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
@Provide()
|
|
129
|
-
export class CurdProService extends BaseService {
|
|
130
|
-
@Inject()
|
|
131
|
-
protected ctx: Context;
|
|
132
|
-
|
|
133
|
-
@Config('mysql2')
|
|
134
|
-
private mysql2Config: any;
|
|
135
|
-
|
|
136
|
-
@Config('postgres2')
|
|
137
|
-
private postgres2Config: any;
|
|
138
|
-
|
|
139
|
-
@Config('sqlserver2')
|
|
140
|
-
private sqlserver2Config: any;
|
|
141
|
-
|
|
142
|
-
@Config('crudProCfg')
|
|
143
|
-
private crudProCfg: ICrudProCfg;
|
|
144
|
-
|
|
145
|
-
private responseCfgHandlers: Record<RelatedType, IExecuteContextHandler> = {} as any;
|
|
146
|
-
|
|
147
|
-
public setResponseCfgHandlers(key: RelatedType, handler: IExecuteContextHandler) {
|
|
148
|
-
this.responseCfgHandlers[key] = handler;
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
public getResponseCfgHandlers(): Record<RelatedType, IExecuteContextHandler> {
|
|
152
|
-
return this.responseCfgHandlers;
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
/**
|
|
156
|
-
* Execute级别:每次调用都会产生新的
|
|
157
|
-
* @private
|
|
158
|
-
*/
|
|
159
|
-
private getCrudPro(): CrudPro {
|
|
160
|
-
const visitor = toVisitor(this.ctx);
|
|
161
|
-
this.logInfo('visitor', JSON.stringify(visitor));
|
|
162
|
-
|
|
163
|
-
const crudPro = new CrudPro();
|
|
164
|
-
crudPro.transaction = this.ctx.transaction;
|
|
165
|
-
crudPro.logger = this.getContextLogger() as any;
|
|
166
|
-
crudPro.visitor = visitor;
|
|
167
|
-
|
|
168
|
-
const crudProCfg: ICrudProCfg = this.crudProCfg || {};
|
|
169
|
-
const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
|
|
170
|
-
crudProCfg.sysDatabaseName = SystemDbName;
|
|
171
|
-
crudProCfg.sysDatabaseDbType = SystemDbType;
|
|
172
|
-
|
|
173
|
-
crudPro.contextCfg = crudProCfg;
|
|
174
|
-
|
|
175
|
-
crudPro.contextFunc = new MyContextFunc(
|
|
176
|
-
{
|
|
177
|
-
mysql2Config: this.mysql2Config,
|
|
178
|
-
postgres2Config: this.postgres2Config,
|
|
179
|
-
sqlserver2Config: this.sqlserver2Config,
|
|
180
|
-
},
|
|
181
|
-
this.responseCfgHandlers
|
|
182
|
-
);
|
|
183
|
-
|
|
184
|
-
return crudPro;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
/**
|
|
188
|
-
* 依赖缓存中与加载的配置
|
|
189
|
-
* @param reqJson
|
|
190
|
-
*/
|
|
191
|
-
async executeCrud(reqJson: IRequestModel): Promise<ExecuteContext> {
|
|
192
|
-
if (!reqJson.method) {
|
|
193
|
-
throw new Error('Method not implemented');
|
|
194
|
-
}
|
|
195
|
-
const curdPro = this.getCrudPro();
|
|
196
|
-
|
|
197
|
-
// 开发环境不使用缓存
|
|
198
|
-
const isEnableCache = !this.isEnableDebug();
|
|
199
|
-
|
|
200
|
-
return curdPro.executeCrud(reqJson, isEnableCache);
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
// 直接执行一个SQL
|
|
204
|
-
public async executeSQL(sqlCfgModel: ISqlCfgModel): Promise<any> {
|
|
205
|
-
const curdPro = this.getCrudPro();
|
|
206
|
-
return curdPro.executeSQL(sqlCfgModel);
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
// 直接执行一个请求
|
|
210
|
-
public async executeCrudByCfg(reqJson: IRequestModel, cfgModel: IRequestCfgModel2): Promise<ExecuteContext> {
|
|
211
|
-
this.logInfo('executeCrudByCfg', cfgModel);
|
|
212
|
-
const curdPro = this.getCrudPro();
|
|
213
|
-
|
|
214
|
-
// 应用标准的updateCfg。
|
|
215
|
-
fixCfgModel(cfgModel);
|
|
216
|
-
return await curdPro.executeCrudByCfg(reqJson, cfgModel);
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
public getBbUtil(sqlDatabase: string, sqlDbType: SqlDbType, sqlTable?: string): CrudProQuick {
|
|
220
|
-
const curdPro = this.getCrudPro();
|
|
221
|
-
return new CrudProQuick(curdPro, sqlDatabase, sqlDbType, sqlTable);
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
public async getCachedCfgByMethod(method: string): Promise<IRequestCfgModel> {
|
|
225
|
-
const curdPro = this.getCrudPro();
|
|
226
|
-
const isEnableCache = !this.isEnableDebug(); // 开发环境不使用缓存
|
|
227
|
-
return curdPro.getCachedCfgByMethod(method, isEnableCache);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CTX_VISITOR_ACCOUNT_TYPE,
|
|
3
|
-
CTX_VISITOR_AVATAR,
|
|
4
|
-
CTX_VISITOR_ID,
|
|
5
|
-
CTX_VISITOR_NICKNAME,
|
|
6
|
-
IRequestCfgModel2
|
|
7
|
-
} from "@/models/bizmodels";
|
|
8
|
-
import {KeysOfSimpleSQL} from "@/libs/crud-pro/models/keys";
|
|
9
|
-
|
|
10
|
-
function isSimpleQuery(sqlSimpleName: KeysOfSimpleSQL): boolean {
|
|
11
|
-
return sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY ||
|
|
12
|
-
sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY_COUNT ||
|
|
13
|
-
sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY_PAGE ||
|
|
14
|
-
sqlSimpleName === KeysOfSimpleSQL.SIMPLE_QUERY_ONE
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
function fixCfgModel(cfgModel: IRequestCfgModel2 ){
|
|
20
|
-
|
|
21
|
-
if (!cfgModel.method) {
|
|
22
|
-
cfgModel.method = 'anonymous';
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
if (!cfgModel.updateCfg) {
|
|
26
|
-
cfgModel.updateCfg = {};
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const sqlSimpleName = cfgModel.sqlSimpleName;
|
|
30
|
-
|
|
31
|
-
const enableStandardUpdateCfg = cfgModel.enableStandardUpdateCfg; // 用于设置data字段
|
|
32
|
-
const enableStandardUpdateCfgCondition = cfgModel.enableStandardUpdateCfgCondition; // 用于设置condition字段
|
|
33
|
-
|
|
34
|
-
// 彻底关闭
|
|
35
|
-
if (enableStandardUpdateCfg === false) {
|
|
36
|
-
return ;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const getDataCfgArray = ()=>{
|
|
40
|
-
// 明确有配置
|
|
41
|
-
if (Array.isArray(enableStandardUpdateCfg)) {
|
|
42
|
-
if (enableStandardUpdateCfg.includes('null')) {
|
|
43
|
-
return [];
|
|
44
|
-
}
|
|
45
|
-
return enableStandardUpdateCfg;
|
|
46
|
-
}
|
|
47
|
-
// update 、insert 添加 by
|
|
48
|
-
return ['by']; // 创建/修改语句默认添加by
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
const getConditionCfgArray = ()=>{
|
|
52
|
-
// 明确有配置
|
|
53
|
-
if (Array.isArray(enableStandardUpdateCfgCondition)) {
|
|
54
|
-
if (enableStandardUpdateCfgCondition.includes('null')) {
|
|
55
|
-
return [];
|
|
56
|
-
}
|
|
57
|
-
return enableStandardUpdateCfgCondition;
|
|
58
|
-
}
|
|
59
|
-
return [];
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
const dataCfgArray = getDataCfgArray();
|
|
64
|
-
const conditionCfgArray = getConditionCfgArray();
|
|
65
|
-
|
|
66
|
-
const mapping = {
|
|
67
|
-
|
|
68
|
-
'condition.created_by': {contextAsString: CTX_VISITOR_ID},
|
|
69
|
-
'condition.created_account_type': {contextAsString: CTX_VISITOR_ACCOUNT_TYPE},
|
|
70
|
-
|
|
71
|
-
'data.created_by': {contextAsString: CTX_VISITOR_ID},
|
|
72
|
-
'data.created_avatar': {contextAsString: CTX_VISITOR_AVATAR},
|
|
73
|
-
'data.created_nickname': {contextAsString: CTX_VISITOR_NICKNAME},
|
|
74
|
-
'data.created_account_type': {contextAsString: CTX_VISITOR_ACCOUNT_TYPE},
|
|
75
|
-
|
|
76
|
-
'data.modified_by': {contextAsString: CTX_VISITOR_ID},
|
|
77
|
-
'data.modified_avatar': {contextAsString: CTX_VISITOR_AVATAR},
|
|
78
|
-
'data.modified_nickname': {contextAsString: CTX_VISITOR_NICKNAME},
|
|
79
|
-
'data.modified_account_type': {contextAsString: CTX_VISITOR_ACCOUNT_TYPE},
|
|
80
|
-
};
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
const buildUpdateCfgBy = (cfgArray: string[], prefix: string): any => {
|
|
84
|
-
const obj: any = {};
|
|
85
|
-
if (Array.isArray(cfgArray)) {
|
|
86
|
-
for (let i = 0; i < cfgArray.length; i++) {
|
|
87
|
-
const suffix = cfgArray[i];
|
|
88
|
-
if (suffix) {
|
|
89
|
-
const key = `${prefix}_${suffix}`
|
|
90
|
-
obj[key] = mapping[key]
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
return obj;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
// 查询语句
|
|
98
|
-
if (isSimpleQuery(sqlSimpleName) ) {
|
|
99
|
-
const updateCfgObj = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 查询用户本人创建的
|
|
100
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
// 删除语句
|
|
104
|
-
if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_DELETE) {
|
|
105
|
-
const updateCfgObj = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 删除用户本人创建的
|
|
106
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
// 插入语句
|
|
110
|
-
if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_INSERT) {
|
|
111
|
-
const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray,'data.created')
|
|
112
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj1);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
// 更新语句
|
|
116
|
-
if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_UPDATE) {
|
|
117
|
-
const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray,'data.modified')
|
|
118
|
-
const updateCfgObj2 = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 更新用户本人创建的
|
|
119
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj1);
|
|
120
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj2);
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
// 插入或更新
|
|
124
|
-
if (sqlSimpleName === KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE ||
|
|
125
|
-
sqlSimpleName === KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE) {
|
|
126
|
-
const updateCfgObj1 = buildUpdateCfgBy(dataCfgArray,'data.created')
|
|
127
|
-
const updateCfgObj2 = buildUpdateCfgBy(dataCfgArray,'data.modified')
|
|
128
|
-
const updateCfgObj3 = buildUpdateCfgBy(conditionCfgArray, 'condition.created'); // 更新用户本人创建的
|
|
129
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj1);
|
|
130
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj2);
|
|
131
|
-
Object.assign(cfgModel.updateCfg, updateCfgObj3);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
export {
|
|
138
|
-
fixCfgModel
|
|
139
|
-
}
|
|
@@ -1,174 +0,0 @@
|
|
|
1
|
-
import { Inject, Provide } from '@midwayjs/core';
|
|
2
|
-
import { Context } from '@midwayjs/koa';
|
|
3
|
-
import * as _ from 'lodash';
|
|
4
|
-
import { BaseService } from '../base/BaseService';
|
|
5
|
-
import { getRouteTrie, RouteTrie } from './RouteTrie';
|
|
6
|
-
import { RouteHandler } from './RouteHandler';
|
|
7
|
-
import { CurdProService } from '../curd/CurdProService';
|
|
8
|
-
import { SystemTables} from '../../models/SystemTables';
|
|
9
|
-
import { KeysOfSimpleSQL } from '../../libs/crud-pro/models/keys';
|
|
10
|
-
import { IProxyApiEntity, IUpstreamInfo } from '../../models/SystemEntities';
|
|
11
|
-
import { parseJsonObject } from '../../libs/utils/functions';
|
|
12
|
-
import { BALANCE_STRATEGY } from './ProxyApiUtils';
|
|
13
|
-
import { WeightedRandom } from './WeightedRandom';
|
|
14
|
-
import { WeightedRoundRobin } from './WeightedRoundRobin';
|
|
15
|
-
import { IScheduleService } from '../../interface';
|
|
16
|
-
import { WorkbenchService } from '../WorkbenchService';
|
|
17
|
-
import { CommonException } from '../../libs/crud-pro/exceptions';
|
|
18
|
-
import { GLOBAL_STATIC_CONFIG } from '@/libs/global-config/global-config';
|
|
19
|
-
|
|
20
|
-
function toUpstreamInfo(config_content: any): IUpstreamInfo {
|
|
21
|
-
const obj = parseJsonObject(config_content);
|
|
22
|
-
if (!obj) {
|
|
23
|
-
return {
|
|
24
|
-
balanceStrategy: BALANCE_STRATEGY.ROUND_ROBIN,
|
|
25
|
-
targetList: [],
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
const targetList = _.get(obj, 'data.targetList', []);
|
|
29
|
-
const balanceStrategy = _.get(obj, 'data.baseInfo.balanceStrategy');
|
|
30
|
-
if (Array.isArray(targetList)) {
|
|
31
|
-
const targetListParsed = targetList
|
|
32
|
-
.map((item: any) => {
|
|
33
|
-
return {
|
|
34
|
-
origin: item.origin,
|
|
35
|
-
weight: item.weight || 1,
|
|
36
|
-
};
|
|
37
|
-
})
|
|
38
|
-
.filter(item => {
|
|
39
|
-
const origin: string = item?.origin || '';
|
|
40
|
-
return origin.startsWith('http://') || origin.startsWith('https://');
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
return {
|
|
44
|
-
balanceStrategy,
|
|
45
|
-
targetList: targetListParsed,
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
return {
|
|
50
|
-
balanceStrategy: BALANCE_STRATEGY.ROUND_ROBIN,
|
|
51
|
-
targetList: [],
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* 接口代理。 数据加载
|
|
57
|
-
*/
|
|
58
|
-
@Provide()
|
|
59
|
-
export class ProxyApiLoadService extends BaseService implements IScheduleService {
|
|
60
|
-
@Inject()
|
|
61
|
-
protected ctx: Context;
|
|
62
|
-
|
|
63
|
-
@Inject()
|
|
64
|
-
private curdProService: CurdProService;
|
|
65
|
-
|
|
66
|
-
@Inject()
|
|
67
|
-
private workbenchService: WorkbenchService;
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* 创建路由树。刷新路由缓存
|
|
71
|
-
* @param workbench_code
|
|
72
|
-
*/
|
|
73
|
-
public async buildRouteTrie(workbench_code: string): Promise<RouteTrie> {
|
|
74
|
-
const upstreamMap: Record<string, IUpstreamInfo> = await this.buildUpstreamMap();
|
|
75
|
-
const routeTrie = getRouteTrie(workbench_code);
|
|
76
|
-
routeTrie.clearRoute();
|
|
77
|
-
const entities = await this.loadProxyApiEntity(workbench_code, upstreamMap);
|
|
78
|
-
for (let i = 0; i < entities.length; i++) {
|
|
79
|
-
const entity = entities[i];
|
|
80
|
-
if (entity.status === 1) {
|
|
81
|
-
const path_prefix2 = '/' + entity.upstream_code + entity.path_prefix;
|
|
82
|
-
routeTrie.addRoute(path_prefix2, new RouteHandler(entity));
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
return routeTrie;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
private async buildUpstreamMap() {
|
|
89
|
-
|
|
90
|
-
const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
|
|
91
|
-
|
|
92
|
-
// biz_tag={'upstream'}
|
|
93
|
-
const res = await this.curdProService.executeCrudByCfg(
|
|
94
|
-
{
|
|
95
|
-
condition: {
|
|
96
|
-
biz_tag: 'upstream',
|
|
97
|
-
},
|
|
98
|
-
},
|
|
99
|
-
{
|
|
100
|
-
sqlTable: SystemTables.sys_configs,
|
|
101
|
-
sqlDatabase: SystemDbName,
|
|
102
|
-
sqlDbType: SystemDbType,
|
|
103
|
-
sqlSimpleName: KeysOfSimpleSQL.SIMPLE_QUERY,
|
|
104
|
-
}
|
|
105
|
-
);
|
|
106
|
-
const upstreamMap: Record<string, IUpstreamInfo> = {};
|
|
107
|
-
const rows = res.getResRows() as any[];
|
|
108
|
-
for (let i = 0; i < rows.length; i++) {
|
|
109
|
-
const row = rows[i];
|
|
110
|
-
const { config_code, config_content } = row || {};
|
|
111
|
-
upstreamMap[config_code] = toUpstreamInfo(config_content);
|
|
112
|
-
}
|
|
113
|
-
return upstreamMap;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
private async loadProxyApiEntity(workbench_code: string, upstreamMap: Record<string, IUpstreamInfo>): Promise<IProxyApiEntity[]> {
|
|
117
|
-
|
|
118
|
-
const { SystemDbName, SystemDbType } = GLOBAL_STATIC_CONFIG.getConfig();
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
const res = await this.curdProService.executeCrudByCfg(
|
|
122
|
-
{
|
|
123
|
-
condition: {},
|
|
124
|
-
},
|
|
125
|
-
{
|
|
126
|
-
sqlTable: SystemTables.sys_proxyapi,
|
|
127
|
-
sqlDatabase: SystemDbName,
|
|
128
|
-
sqlDbType: SystemDbType,
|
|
129
|
-
sqlSimpleName: KeysOfSimpleSQL.SIMPLE_QUERY,
|
|
130
|
-
}
|
|
131
|
-
);
|
|
132
|
-
|
|
133
|
-
const rows0 = res.getResRows() as IProxyApiEntity[];
|
|
134
|
-
|
|
135
|
-
const rows = rows0.filter(s => {
|
|
136
|
-
if (!s.workbench_code_array) {
|
|
137
|
-
throw new CommonException('IS_SUPPORT_CURRENT_WORKBENCH', '未配置支持的站点字段');
|
|
138
|
-
}
|
|
139
|
-
return this.workbenchService.isMatchWorkbenchCode(s.workbench_code_array, workbench_code);
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
for (let i = 0; i < rows.length; i++) {
|
|
143
|
-
const row = rows[i];
|
|
144
|
-
const upstream_code = row.upstream_code;
|
|
145
|
-
this.addUpstreamInfo(row, upstream_code, upstreamMap);
|
|
146
|
-
}
|
|
147
|
-
return rows;
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
private addUpstreamInfo(row: IProxyApiEntity, upstream_code: string, upstreamMap: Record<string, IUpstreamInfo>) {
|
|
151
|
-
const upstreamInfo = upstreamMap[upstream_code];
|
|
152
|
-
if (!upstreamInfo) {
|
|
153
|
-
return;
|
|
154
|
-
}
|
|
155
|
-
row.targetIndex = 0;
|
|
156
|
-
row.targetList = upstreamInfo.targetList || [];
|
|
157
|
-
row.balanceStrategy = upstreamInfo.balanceStrategy || BALANCE_STRATEGY.ROUND_ROBIN;
|
|
158
|
-
row.weightedRandom = new WeightedRandom(upstreamInfo.targetList || []);
|
|
159
|
-
row.weightedRoundRobin = new WeightedRoundRobin(upstreamInfo.targetList || []);
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
public async runBySchedule(): Promise<any> {
|
|
163
|
-
const workbenchList = await this.workbenchService.getAllWorkbenchInfoList();
|
|
164
|
-
for (let i = 0; i < workbenchList.length; i++) {
|
|
165
|
-
const workbenchInfo = workbenchList[i];
|
|
166
|
-
try {
|
|
167
|
-
await this.buildRouteTrie(workbenchInfo.workbench_code);
|
|
168
|
-
} catch (e) {
|
|
169
|
-
this.logError('ProxyApiLoadService_runBySchedule', e);
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
}
|