|
|
|
@ -3,10 +3,12 @@ package cn.estsh.i3plus.core.apiservice.mq;
|
|
|
|
|
import cn.estsh.i3plus.core.api.iservice.busi.ISysPojoVersionDetailService;
|
|
|
|
|
import cn.estsh.i3plus.core.api.iservice.busi.ISysPojoVersionService;
|
|
|
|
|
import cn.estsh.i3plus.platform.common.convert.ConvertBean;
|
|
|
|
|
import cn.estsh.i3plus.platform.common.tool.ExcelTool;
|
|
|
|
|
import cn.estsh.i3plus.platform.common.tool.JsonUtilTool;
|
|
|
|
|
import cn.estsh.i3plus.platform.common.util.CommonConstWords;
|
|
|
|
|
import cn.estsh.i3plus.pojo.base.codemaker.SnowflakeIdMaker;
|
|
|
|
|
import cn.estsh.i3plus.pojo.base.enumutil.CommonEnumUtil;
|
|
|
|
|
import cn.estsh.i3plus.pojo.platform.bean.SysConfig;
|
|
|
|
|
import cn.estsh.i3plus.pojo.platform.bean.SysPojoVersion;
|
|
|
|
|
import cn.estsh.i3plus.pojo.platform.bean.SysPojoVersionDetail;
|
|
|
|
|
import cn.estsh.i3plus.pojo.platform.bean.SysPojoVersionPlan;
|
|
|
|
@ -25,7 +27,6 @@ import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnExpression;
|
|
|
|
|
import org.springframework.context.annotation.Bean;
|
|
|
|
|
import org.springframework.context.annotation.Configuration;
|
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
@ -61,6 +62,7 @@ public class PojoVersionQueueReceiver {
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* QUEUE_SWEB_NOTICE 队列
|
|
|
|
|
*
|
|
|
|
|
* @return 队列
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
@ -86,6 +88,7 @@ public class PojoVersionQueueReceiver {
|
|
|
|
|
SysPojoVersionPlan versionPlan = JSON.parseObject(redisValue.toString(), SysPojoVersionPlan.class);
|
|
|
|
|
Map<String, Object> afterMap = JsonUtilTool.decode(afterVersion.getBean(), Map.class);
|
|
|
|
|
SysPojoVersionDetail afterVersionDetail = null;
|
|
|
|
|
Map<String, String> mapPropDesc = afterVersion.getPojoPropDesc();
|
|
|
|
|
|
|
|
|
|
// 已存在数据
|
|
|
|
|
SysPojoVersion beforeVersion = null;
|
|
|
|
@ -94,8 +97,7 @@ public class PojoVersionQueueReceiver {
|
|
|
|
|
|
|
|
|
|
Integer versionNo; // 对象版本
|
|
|
|
|
CommonEnumUtil.DAO_OPERATE_TYPE operateType = CommonEnumUtil.DAO_OPERATE_TYPE.INSERT; // 操作类型
|
|
|
|
|
Map<String, MapDifference.ValueDifference<Object>> differing; // 版本对比
|
|
|
|
|
String pojoCompare = null;
|
|
|
|
|
Map<String, MapDifference.ValueDifference<Object>> mapDiff; // 版本对比
|
|
|
|
|
String userName = StringUtils.isNotBlank(afterVersion.getModifyUser()) ? afterVersion.getModifyUser() : afterVersion.getCreateUser();
|
|
|
|
|
|
|
|
|
|
if (!"insert".equals(afterVersion.getVersionMethodName())) { // 不是新增数据的时候则需要查询历史记录
|
|
|
|
@ -119,8 +121,7 @@ public class PojoVersionQueueReceiver {
|
|
|
|
|
afterMap.remove(key);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
differing = Maps.difference(beforeMap, afterMap).entriesDiffering();
|
|
|
|
|
mapDiff = Maps.difference(beforeMap, afterMap).entriesDiffering();
|
|
|
|
|
// // 忽略版本控制属性
|
|
|
|
|
// if(differing != null ){
|
|
|
|
|
// for (String key : CommonConstWords.POJO_VERSION_ATTR_INGNORE) {
|
|
|
|
@ -130,7 +131,7 @@ public class PojoVersionQueueReceiver {
|
|
|
|
|
// }
|
|
|
|
|
// pojoCompare = differing.toString();
|
|
|
|
|
// }
|
|
|
|
|
pojoCompare = differing != null && differing.size() > 0 ? differing.toString() : null;
|
|
|
|
|
String pojoCompare = mapDiff == null ? null : mapDiff.toString();
|
|
|
|
|
|
|
|
|
|
versionNo = Objects.nonNull(beforeVersion) ? beforeVersion.getVersionNo() : 0;
|
|
|
|
|
afterVersion.setVersionNo(++versionNo);
|
|
|
|
@ -141,15 +142,22 @@ public class PojoVersionQueueReceiver {
|
|
|
|
|
afterVersionDetail = new SysPojoVersionDetail();
|
|
|
|
|
afterVersionDetail.setId(snowflakeIdMaker.nextId());
|
|
|
|
|
afterVersionDetail.setPojoVersionId(afterVersion.getId());
|
|
|
|
|
|
|
|
|
|
afterVersionDetail.setPojoBefore(JSON.toJSONString(beforeMap));
|
|
|
|
|
afterVersionDetail.setPojoAfter(JSON.toJSONString(afterMap));
|
|
|
|
|
afterVersionDetail.setPojoCompare(pojoCompare);
|
|
|
|
|
|
|
|
|
|
afterVersionDetail.setPojoBeforeTxt(getMapToStr(beforeMap, mapPropDesc));
|
|
|
|
|
afterVersionDetail.setPojoAfterTxt(getMapToStr(afterMap, mapPropDesc));
|
|
|
|
|
afterVersionDetail.setPojoCompareTxt(getMapDiffToStr(mapDiff, mapPropDesc));
|
|
|
|
|
|
|
|
|
|
ConvertBean.serviceModelInitialize(afterVersionDetail, userName);
|
|
|
|
|
pojoVersionDetailService.insert(afterVersionDetail);
|
|
|
|
|
|
|
|
|
|
afterVersion.setOperateType(operateType.getValue());
|
|
|
|
|
afterVersion.setVersionNo(versionNo);
|
|
|
|
|
afterVersion.setPojoCompare(pojoCompare);
|
|
|
|
|
afterVersion.setPojoCompareTxt(getMapDiffToStr(mapDiff, mapPropDesc));
|
|
|
|
|
afterVersion.setPojoDetailId(afterVersionDetail.getId());
|
|
|
|
|
ConvertBean.serviceModelInitialize(afterVersion, userName);
|
|
|
|
|
pojoVersionService.insert(afterVersion);
|
|
|
|
@ -171,4 +179,84 @@ public class PojoVersionQueueReceiver {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Map数据转文本
|
|
|
|
|
*
|
|
|
|
|
* @param mapData
|
|
|
|
|
* @param mapPropDesc
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
|
|
|
|
private String getMapToStr(Map<String, Object> mapData, Map<String, String> mapPropDesc) {
|
|
|
|
|
if (mapData == null) {
|
|
|
|
|
mapData = new HashMap<>();
|
|
|
|
|
}
|
|
|
|
|
if (mapPropDesc == null) {
|
|
|
|
|
mapData = new HashMap<>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StringBuilder stringBuffer = new StringBuilder();
|
|
|
|
|
String key;
|
|
|
|
|
for (Map.Entry<String, Object> entry : mapData.entrySet()) {
|
|
|
|
|
key = mapPropDesc.get(entry.getKey());
|
|
|
|
|
if (key == null) {
|
|
|
|
|
key = entry.getKey();
|
|
|
|
|
}
|
|
|
|
|
stringBuffer.append(key).append(":").append(entry.getValue()).append(",");
|
|
|
|
|
}
|
|
|
|
|
return stringBuffer.toString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* MapDifference数据转文本
|
|
|
|
|
*
|
|
|
|
|
* @param mapData
|
|
|
|
|
* @param mapPropDesc
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
|
|
|
|
private String getMapDiffToStr(Map<String, MapDifference.ValueDifference<Object>> mapData, Map<String, String> mapPropDesc) {
|
|
|
|
|
if (mapData == null) {
|
|
|
|
|
mapData = new HashMap<>();
|
|
|
|
|
}
|
|
|
|
|
if (mapPropDesc == null) {
|
|
|
|
|
mapData = new HashMap<>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StringBuilder stringBuffer = new StringBuilder();
|
|
|
|
|
String key;
|
|
|
|
|
MapDifference.ValueDifference<Object> valDiff;
|
|
|
|
|
for (Map.Entry<String, MapDifference.ValueDifference<Object>> entry : mapData.entrySet()) {
|
|
|
|
|
valDiff = entry.getValue();
|
|
|
|
|
if (valDiff == null) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
key = mapPropDesc.get(entry.getKey());
|
|
|
|
|
if (key == null) {
|
|
|
|
|
key = entry.getKey();
|
|
|
|
|
}
|
|
|
|
|
stringBuffer.append("修改值 ").append(key)
|
|
|
|
|
.append(",旧值为 ").append(valDiff.leftValue())
|
|
|
|
|
.append(",新值为 ").append(valDiff.rightValue())
|
|
|
|
|
.append("。");
|
|
|
|
|
}
|
|
|
|
|
return stringBuffer.toString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void main(String[] args) {
|
|
|
|
|
Map<String, String> orginMap = new HashMap<>();
|
|
|
|
|
orginMap.put("name", "wyh");
|
|
|
|
|
orginMap.put("age", "18");
|
|
|
|
|
orginMap.put("sex", "male");
|
|
|
|
|
Map<String, String> newMap = new HashMap<>();
|
|
|
|
|
newMap.put("name", "hyw");
|
|
|
|
|
newMap.put("age", "81");
|
|
|
|
|
MapDifference mapDiff = Maps.difference(orginMap, newMap);
|
|
|
|
|
System.out.println(mapDiff.entriesDiffering());
|
|
|
|
|
System.out.println(mapDiff.entriesInCommon());
|
|
|
|
|
System.out.println(mapDiff.entriesOnlyOnLeft());
|
|
|
|
|
System.out.println(mapDiff.entriesOnlyOnRight());
|
|
|
|
|
System.out.println(mapDiff.areEqual());
|
|
|
|
|
|
|
|
|
|
System.out.println(ExcelTool.getColName(SysConfig.class));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|