优化ResponseDeal

dev
ic_excellent 2023-07-27 14:12:35 +08:00
parent afb20960b9
commit 5a8ef40e18
1 changed files with 58 additions and 39 deletions

View File

@ -200,33 +200,15 @@ public class ResponseMappingDeal {
throw new ResponseException(customerException);
}
}
for (Map<String, Object> mainItem : mainList) {
aliasData.put(mainDataAlias.getDataAlias(), mainItem);
// 处理配置信息
List<FieldDefinition> fieldDefinitions = parsingJsonToConfig(valueChangeList, aliasData);
RowDefinition rowDefinition = this.buildRowDefinition(fieldDefinitions, tableName, mainDataAlias.getAssignType(), mainDataAlias.getConditionScript(), mainDataAlias.getJudgmentScript());
rowDefinition.setMainOrDetail(ResponseConfigConstant.DETAIL_TABLE);
if (isMainTable) {
Map<String, TableDefinition> detailTable = new HashMap<>();
rowDefinition.setMainOrDetail(ResponseConfigConstant.MAIN_TABLE);
detailCallBack.apply(responseConfig, aliasData, detailTable);
rowDefinition.setDetailTableMap(detailTable);
if(ResponseUtil.parameterIsNotNull(mainList)) {
for (Map<String, Object> mainItem : mainList) {
RowDefinition rowDefinition = this.buildRowDefinition(mainDataAlias, tableName, isMainTable, aliasData, mainItem, valueChangeList, responseConfig, detailCallBack);
rowDefinitionList.add(rowDefinition);
}
rowDefinitionList.add(rowDefinition);
}
} else if (mainDataAlias.getDataType() == ResponseConfigConstant.JSON_OBJECT) {
Map<String, Object> jsonObj = (Map<String, Object>) Util.getValueByKeyStr(dataPath, aliasData);
aliasData.put(mainDataAlias.getDataAlias(), jsonObj);
// 处理配置信息
List<FieldDefinition> fieldDefinitions = parsingJsonToConfig(valueChangeList, aliasData);
RowDefinition rowDefinition = this.buildRowDefinition(fieldDefinitions, tableName, mainDataAlias.getAssignType(), mainDataAlias.getConditionScript(), mainDataAlias.getJudgmentScript());
rowDefinition.setMainOrDetail(ResponseConfigConstant.DETAIL_TABLE);
if (isMainTable) {
Map<String, TableDefinition> detailTable = new HashMap<>();
rowDefinition.setMainOrDetail(ResponseConfigConstant.MAIN_TABLE);
detailCallBack.apply(responseConfig, aliasData, detailTable);
rowDefinition.setDetailTableMap(detailTable);
}
RowDefinition rowDefinition = this.buildRowDefinition(mainDataAlias, tableName, isMainTable, aliasData, jsonObj, valueChangeList, responseConfig, detailCallBack);
rowDefinitionList.add(rowDefinition);
} else {
throw new ResponseException("please set the primary data type !!!");
@ -235,15 +217,35 @@ public class ResponseMappingDeal {
tableDefinition.setRowDefinitionList(rowDefinitionList);
return tableDefinition;
}
private RowDefinition buildRowDefinition(List<FieldDefinition> fieldDefinitionList,
String tableName,
int assignType,
String conditionScript,
String judgmentScript) {
/**
* json
* @param mainDataAlias
* @param tableName
* @param isMainTable
* @param aliasData json
* @param jsonObj json
* @param valueChangeList
* @param responseConfig
* @param detailCallBack
* @return
*/
private RowDefinition buildRowDefinition(ResponseConfigAlias mainDataAlias,
String tableName,
boolean isMainTable,
Map<String,Object> aliasData,
Map<String,Object> jsonObj,
List<ResponseConfigValueChange> valueChangeList,
ResponseConfig responseConfig,
Bi3Function<ResponseConfig, Map<String, Object>, Map<String, TableDefinition>, String> detailCallBack){
// 将当前行的json信息放入别名map
aliasData.put(mainDataAlias.getDataAlias(), jsonObj);
//通过字段转换配置将json转为字段描述
List<FieldDefinition> fieldDefinitions = parsingJsonToConfig(valueChangeList, aliasData);
Map<String, Object> updateParam = new HashMap<>();
Map<String, Object> wherePram = new HashMap<>();
fieldDefinitionList.forEach(fieldDefinition -> {
//构建用于更新和作为条件的map
fieldDefinitions.forEach(fieldDefinition -> {
int fieldType = fieldDefinition.getFieldType();
if (fieldType == ResponseConfigConstant.WHERE_FIELD) {
wherePram.put(fieldDefinition.getFieldName(), fieldDefinition.getFieldValue());
@ -252,16 +254,33 @@ public class ResponseMappingDeal {
wherePram.put(fieldDefinition.getFieldName(), fieldDefinition.getFieldValue());
}
});
return RowDefinition.builder().assignType(assignType)
.conditionScript(conditionScript)
.updateParam(updateParam)
.assignTable(tableName)
.whereParam(wherePram)
.fieldDefinitionList(fieldDefinitionList)
.rowDefinitionCallback(this.rowCallback)
.judgmentScript(judgmentScript).build();
//构建行描述信息
RowDefinition rowDefinition = RowDefinition.builder().assignType(mainDataAlias.getAssignType())
.conditionScript(mainDataAlias.getConditionScript())
.updateParam(updateParam)
.assignTable(tableName)
.whereParam(wherePram)
.fieldDefinitionList(fieldDefinitions)
.rowDefinitionCallback(this.rowCallback)
.judgmentScript(mainDataAlias.getJudgmentScript()).build();
rowDefinition.setMainOrDetail(ResponseConfigConstant.DETAIL_TABLE);
//判断是否为主表,为主表则需处理其明细信息
if (isMainTable) {
Map<String, TableDefinition> detailTable = new HashMap<>();
rowDefinition.setMainOrDetail(ResponseConfigConstant.MAIN_TABLE);
detailCallBack.apply(responseConfig, aliasData, detailTable);
rowDefinition.setDetailTableMap(detailTable);
}
return rowDefinition;
}
/**
* json
* @param responseConfig
* @param param json
* @param detailTable map
* @return
*/
private String detailTableDeal(ResponseConfig responseConfig, Map<String, Object> param, Map<String, TableDefinition> detailTable) {
List<ResponseConfigAlias> responseConfigAliasList = responseConfig.getResponseConfigAliasList();
List<ResponseConfigValueChange> valueChangeList = responseConfig.getValueChangeList();