use of com.webank.wedatasphere.qualitis.request.GetUserColumnByTableIdRequest in project Qualitis by WeBankFinTech.
the class MetaDataServiceImpl method constructRequest.
private AddMultiSourceRuleRequest constructRequest(MulDbRequest request, FilterRequest filterRequest, String currentSourceTable, String currentTargetTable, int index, int total, String loginUser) throws UnExpectedRequestException, MetaDataAcquireFailedException, IOException {
LOGGER.info("Start to construct add multi source rule request.");
// rule basic info.
AddMultiSourceRuleRequest addMultiSourceRuleRequest = new AddMultiSourceRuleRequest();
basicInfo(addMultiSourceRuleRequest, request, index, total);
MultiDataSourceConfigRequest sourceConfigRequest = new MultiDataSourceConfigRequest();
sourceConfigRequest.setLinkisDataSourceName(request.getSourceLinkisDataSourceName());
sourceConfigRequest.setLinkisDataSourceType(request.getSourceLinkisDataSourceType());
sourceConfigRequest.setLinkisDataSourceId(request.getSourceLinkisDataSourceId());
sourceConfigRequest.setProxyUser(request.getProxyUser());
sourceConfigRequest.setDbName(request.getSourceDb());
sourceConfigRequest.setContextService(false);
MultiDataSourceConfigRequest targetConfigRequest = new MultiDataSourceConfigRequest();
targetConfigRequest.setLinkisDataSourceName(request.getTargetLinkisDataSourceName());
targetConfigRequest.setLinkisDataSourceType(request.getTargetLinkisDataSourceType());
targetConfigRequest.setLinkisDataSourceId(request.getTargetLinkisDataSourceId());
targetConfigRequest.setProxyUser(request.getProxyUser());
targetConfigRequest.setDbName(request.getTargetDb());
targetConfigRequest.setContextService(false);
if (filterRequest == null) {
// source table and target table
sourceConfigRequest.setTableName(currentSourceTable);
sourceConfigRequest.setFilter("true");
targetConfigRequest.setTableName(currentTargetTable);
targetConfigRequest.setFilter("true");
addMultiSourceRuleRequest.setMultiSourceRuleTemplateId(20L);
List<AlarmConfigRequest> alarmConfigRequests = new ArrayList<>();
alarmConfigRequests.add(new AlarmConfigRequest(645L, CheckTemplateEnum.FIXED_VALUE.getCode(), CompareTypeEnum.EQUAL.getCode(), 0.0));
addMultiSourceRuleRequest.setAlarmVariable(alarmConfigRequests);
} else {
sourceConfigRequest.setTableName(filterRequest.getSourceTable());
if (StringUtils.isNotBlank(filterRequest.getSourceFilter())) {
sourceConfigRequest.setFilter("! (" + filterRequest.getSourceFilter() + ")");
} else {
sourceConfigRequest.setFilter("true");
}
targetConfigRequest.setTableName(filterRequest.getTargetTable());
if (StringUtils.isNotBlank(filterRequest.getTargetFilter())) {
targetConfigRequest.setFilter("! (" + filterRequest.getTargetFilter() + ")");
} else {
targetConfigRequest.setFilter("true");
}
addMultiSourceRuleRequest.setMultiSourceRuleTemplateId(17L);
List<AlarmConfigRequest> alarmConfigRequests = new ArrayList<>();
alarmConfigRequests.add(new AlarmConfigRequest(33L, CheckTemplateEnum.FIXED_VALUE.getCode(), CompareTypeEnum.EQUAL.getCode(), 0.0));
addMultiSourceRuleRequest.setAlarmVariable(alarmConfigRequests);
}
addMultiSourceRuleRequest.setSource(sourceConfigRequest);
addMultiSourceRuleRequest.setTarget(targetConfigRequest);
// All fields mappings
LOGGER.info("Start to get all fields with source database's table and target database's table.");
List<ColumnInfoDetail> sourceFields;
List<ColumnInfoDetail> targetFields;
if (request.getSourceLinkisDataSourceId() == null) {
GetUserColumnByTableIdRequest getUserColumnSourceRequest = new GetUserColumnByTableIdRequest(0, Integer.MAX_VALUE, request.getClusterName(), request.getSourceDb(), filterRequest == null ? currentSourceTable : filterRequest.getSourceTable());
getUserColumnSourceRequest.setProxyUser(request.getProxyUser());
getUserColumnSourceRequest.setLoginUser(loginUser);
sourceFields = getUserColumnByTableId(getUserColumnSourceRequest).getData().getData();
} else {
sourceFields = getColumnsByDataSource(request.getClusterName(), request.getProxyUser(), request.getSourceLinkisDataSourceId(), request.getSourceDb(), currentSourceTable).getData().getData();
}
if (request.getTargetLinkisDataSourceId() == null) {
GetUserColumnByTableIdRequest getUserColumnTargetRequest = new GetUserColumnByTableIdRequest(0, Integer.MAX_VALUE, request.getClusterName(), request.getTargetDb(), filterRequest == null ? currentTargetTable : filterRequest.getTargetTable());
getUserColumnTargetRequest.setProxyUser(request.getProxyUser());
getUserColumnTargetRequest.setLoginUser(loginUser);
targetFields = getUserColumnByTableId(getUserColumnTargetRequest).getData().getData();
} else {
targetFields = getColumnsByDataSource(request.getClusterName(), request.getProxyUser(), request.getTargetLinkisDataSourceId(), request.getTargetDb(), currentTargetTable).getData().getData();
}
if (CollectionUtils.isEmpty(sourceFields) || CollectionUtils.isEmpty(targetFields)) {
throw new UnExpectedRequestException("There is table which has none field");
}
LOGGER.info("Success to get all fields with source database's table and target database's table.");
// Sorted columns.
Collections.sort(sourceFields, new Comparator<ColumnInfoDetail>() {
@Override
public int compare(ColumnInfoDetail front, ColumnInfoDetail back) {
return front.getFieldName().compareTo(back.getFieldName());
}
});
Collections.sort(targetFields, new Comparator<ColumnInfoDetail>() {
@Override
public int compare(ColumnInfoDetail front, ColumnInfoDetail back) {
return front.getFieldName().compareTo(back.getFieldName());
}
});
String sourceFieldStr = sourceFields.stream().map(ColumnInfoDetail::getFieldName).collect(Collectors.joining(SpecCharEnum.COMMA.getValue()));
String sourceFieldTypeStr = sourceFields.stream().map(ColumnInfoDetail::getDataType).collect(Collectors.joining(SpecCharEnum.COMMA.getValue()));
String targetFieldStr = targetFields.stream().map(ColumnInfoDetail::getFieldName).collect(Collectors.joining(SpecCharEnum.COMMA.getValue()));
String targetFieldTypeStr = targetFields.stream().map(ColumnInfoDetail::getDataType).collect(Collectors.joining(SpecCharEnum.COMMA.getValue()));
if (sourceFields.size() == 0 || targetFields.size() == 0 || sourceFields.size() != targetFields.size() || !sourceFieldStr.equals(targetFieldStr) || !sourceFieldTypeStr.equals(targetFieldTypeStr)) {
throw new UnExpectedRequestException("Create multi-db rules failed, because the fields' name of table is different.");
}
List<MultiDataSourceJoinConfigRequest> mappings = new ArrayList<>(sourceFields.size());
for (int j = 0; j < sourceFields.size() && j < targetFields.size(); j++) {
ColumnInfoDetail currentSourceField = sourceFields.get(j);
ColumnInfoDetail currentTargetField = targetFields.get(j);
if (filterRequest != null && CollectionUtils.isNotEmpty(filterRequest.getFilterColumnList()) && filterRequest.getFilterColumnList().contains(currentSourceField.getFieldName())) {
continue;
}
if (currentSourceField.getFieldName().equals(currentTargetField.getFieldName()) && currentSourceField.getDataType().equals(currentTargetField.getDataType())) {
// TODO: continue
MultiDataSourceJoinConfigRequest multiDataSourceJoinConfigRequest = new MultiDataSourceJoinConfigRequest();
MultiDataSourceJoinColumnRequest leftJoinColumnRequest = new MultiDataSourceJoinColumnRequest("tmp1.".concat(currentSourceField.getFieldName()), currentSourceField.getDataType());
MultiDataSourceJoinColumnRequest rightJoinColumnRequest = new MultiDataSourceJoinColumnRequest("tmp2.".concat(currentTargetField.getFieldName()), currentTargetField.getDataType());
multiDataSourceJoinConfigRequest.setOperation(MappingOperationEnum.EQUAL.getCode());
multiDataSourceJoinConfigRequest.setLeft(Arrays.asList(leftJoinColumnRequest));
multiDataSourceJoinConfigRequest.setRight(Arrays.asList(rightJoinColumnRequest));
multiDataSourceJoinConfigRequest.setLeftStatement("tmp1.".concat(currentSourceField.getFieldName()));
multiDataSourceJoinConfigRequest.setRightStatement("tmp2.".concat(currentTargetField.getFieldName()));
mappings.add(multiDataSourceJoinConfigRequest);
} else {
throw new UnExpectedRequestException("Create multi-db rules failed, because the fields' name of tables is different");
}
}
addMultiSourceRuleRequest.setMappings(mappings);
addMultiSourceRuleRequest.setLoginUser(loginUser);
LOGGER.info("Success to construct add multi source rule request. Request[{}]", new ObjectMapper().writeValueAsString(addMultiSourceRuleRequest));
return addMultiSourceRuleRequest;
}
Aggregations