From b863cc7f007a953a794c09729a034f5d34b26d9b Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 27 八月 2019 17:08:45 +0800
Subject: [PATCH] 个人信息维护修改

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoModifyRecordServiceImpl.java |   83 +++++++++++++++++++++++++++++++++++++----
 1 files changed, 74 insertions(+), 9 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoModifyRecordServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoModifyRecordServiceImpl.java
index 60b16c6..e51187d 100644
--- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoModifyRecordServiceImpl.java
+++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserInfoModifyRecordServiceImpl.java
@@ -8,11 +8,19 @@
 import org.springframework.stereotype.Service;
 
 import com.yeshi.fanli.dao.mybatis.user.UserInfoModifyRecordMapper;
+import com.yeshi.fanli.entity.bus.user.BindingAccount;
+import com.yeshi.fanli.entity.bus.user.UserExtraTaoBaoInfo;
+import com.yeshi.fanli.entity.bus.user.UserInfo;
+import com.yeshi.fanli.entity.bus.user.UserInfoExtra;
 import com.yeshi.fanli.entity.bus.user.UserInfoModifyRecord;
 import com.yeshi.fanli.entity.bus.user.UserInfoModifyRecord.ModifyTypeEnum;
 import com.yeshi.fanli.log.LogHelper;
 import com.yeshi.fanli.service.inter.integral.IntegralGetService;
+import com.yeshi.fanli.service.inter.user.BindingAccountService;
+import com.yeshi.fanli.service.inter.user.UserExtraTaoBaoInfoService;
+import com.yeshi.fanli.service.inter.user.UserInfoExtraService;
 import com.yeshi.fanli.service.inter.user.UserInfoModifyRecordService;
+import com.yeshi.fanli.service.inter.user.UserInfoService;
 import com.yeshi.fanli.util.StringUtil;
 
 @Service
@@ -20,9 +28,21 @@
 
 	@Resource
 	private UserInfoModifyRecordMapper userInfoModifyRecordMapper;
-	
+
 	@Resource
 	private IntegralGetService integralGetService;
+
+	@Resource
+	private UserInfoService userInfoService;
+
+	@Resource
+	private UserInfoExtraService userInfoExtraService;
+
+	@Resource
+	private BindingAccountService bindingAccountService;
+
+	@Resource
+	private UserExtraTaoBaoInfoService userExtraTaoBaoInfoService;
 
 	@Async()
 	@Override
@@ -30,7 +50,7 @@
 		try {
 			if (uid == null || StringUtil.isNullOrEmpty(value))
 				return;
-			
+
 			long count = countByUid(uid, type.name());
 			if (count == 0) {
 				if (type == ModifyTypeEnum.bindPhone) {
@@ -51,13 +71,16 @@
 					integralGetService.addSetWeiXinNum(uid);
 				}
 			}
-			
-			UserInfoModifyRecord record = new UserInfoModifyRecord();
-			record.setUid(uid);
-			record.setType(type);
-			record.setValue(value);
-			record.setCreateTime(new Date());
-			userInfoModifyRecordMapper.insertSelective(record);
+
+			UserInfoModifyRecord oldRecord = userInfoModifyRecordMapper.selectLatestByUidAndType(uid, type.name());
+			if (oldRecord == null || !oldRecord.getValue().equalsIgnoreCase(value)) {// 涓嶈兘淇敼閲嶅鐨勬暟鎹�
+				UserInfoModifyRecord record = new UserInfoModifyRecord();
+				record.setUid(uid);
+				record.setType(type);
+				record.setValue(value);
+				record.setCreateTime(new Date());
+				userInfoModifyRecordMapper.insertSelective(record);
+			}
 		} catch (Exception e) {
 			e.printStackTrace();
 			LogHelper.errorDetailInfo(e);
@@ -68,4 +91,46 @@
 	public long countByUid(Long uid, String type) {
 		return userInfoModifyRecordMapper.countByUid(uid, type);
 	}
+
+	@Override
+	public void syncBeforeInfo(Long uid) {
+		// 鑾峰彇鐢ㄦ埛鍩烘湰淇℃伅
+		UserInfo user = userInfoService.selectByPKey(uid);
+		if (user == null || user.getState() != UserInfo.STATE_NORMAL) {// 鐢ㄦ埛涓嶆甯�
+			return;
+		}
+		if (!StringUtil.isNullOrEmpty(user.getPhone())) {
+			addModifyRecord(uid, ModifyTypeEnum.bindPhone, user.getPhone());
+		}
+
+		BindingAccount account = bindingAccountService.getBindingAccountByUidAndType(uid, BindingAccount.TYPE_ALIPAY);
+		if (account != null) {
+			addModifyRecord(uid, ModifyTypeEnum.bindAlipay, account.getAccount());
+		}
+
+		if (!StringUtil.isNullOrEmpty(user.getWxUnionId())) {
+			addModifyRecord(uid, ModifyTypeEnum.bindWeiXin, user.getWxUnionId());
+		}
+
+		if (user.getNickName() != null && !user.getNickName().startsWith("杩斿埄鍒�")) {
+			addModifyRecord(uid, ModifyTypeEnum.nickName, user.getNickName() + "");
+		}
+
+		UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid);
+		if (userInfoExtra != null) {
+			if (userInfoExtra.getSex() != null)
+				addModifyRecord(uid, ModifyTypeEnum.gender, userInfoExtra.getSex() + "");
+
+			if (!StringUtil.isNullOrEmpty(userInfoExtra.getWeiXin()))
+				addModifyRecord(uid, ModifyTypeEnum.setWeiXinNum, userInfoExtra.getWeiXin());
+		}
+
+		UserExtraTaoBaoInfo taoBaoExtra = userExtraTaoBaoInfoService.getByUid(uid);
+		if (taoBaoExtra != null && !StringUtil.isNullOrEmpty(taoBaoExtra.getRelationId())
+				&& !StringUtil.isNullOrEmpty(taoBaoExtra.getSpecialId()) && taoBaoExtra.getRelationValid()
+				&& taoBaoExtra.getSpecialValid()) {
+			addModifyRecord(uid, ModifyTypeEnum.bindTaoBao, taoBaoExtra.getTaoBaoUid());
+		}
+
+	}
 }

--
Gitblit v1.8.0