From 744594ef1a2f530fc3e86ea9dc48b62247f79420 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 19 五月 2020 17:13:23 +0800
Subject: [PATCH] 饿了么绘图,添加口碑

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java |   59 ++++++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 44 insertions(+), 15 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java
index 6018124..24e850e 100644
--- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java
+++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java
@@ -23,8 +23,12 @@
 import com.yeshi.fanli.entity.bus.user.vip.UserLevelUpgradedNotify;
 import com.yeshi.fanli.entity.bus.user.vip.UserVIPInfo;
 import com.yeshi.fanli.entity.bus.user.vip.UserVIPPreInfo;
+import com.yeshi.fanli.entity.common.Config;
+import com.yeshi.fanli.entity.system.ConfigKeyEnum;
 import com.yeshi.fanli.exception.user.vip.UserVIPInfoException;
 import com.yeshi.fanli.exception.user.vip.UserVIPPreInfoException;
+import com.yeshi.fanli.log.LogHelper;
+import com.yeshi.fanli.service.inter.config.ConfigService;
 import com.yeshi.fanli.service.inter.count.HongBaoV2CountService;
 import com.yeshi.fanli.service.inter.user.UserInfoService;
 import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce;
@@ -38,6 +42,7 @@
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.StringUtil;
 import com.yeshi.fanli.util.TimeUtil;
+import com.yeshi.fanli.util.email.MailSenderUtil;
 import com.yeshi.fanli.util.rocketmq.MQMsgBodyFactory;
 import com.yeshi.fanli.util.rocketmq.MQTopicName;
 
@@ -77,6 +82,9 @@
 
 	@Resource(name = "producer")
 	private Producer producer;
+
+	@Resource
+	private ConfigService configService;
 
 	@Override
 	@Transactional(rollbackFor = Exception.class)
@@ -153,7 +161,8 @@
 			throw new UserVIPInfoException(1, "璇峰厛鍗囩骇涓洪珮绾т細鍛�");
 		}
 
-		if (!verifyVip(uid))
+		int verifyResult = verifyVip(uid);
+		if (verifyResult <= 0)
 			throw new UserVIPInfoException(1, "涓嶆弧瓒冲崌绾ф潯浠�");
 
 		UserVIPInfo userInfo = userVIPInfoMapper.selectByPrimaryKeyForUpdate(uid);
@@ -172,6 +181,22 @@
 		info.setState(UserVIPInfo.STATE_VERIFING);
 		info.setUpdateTime(new Date());
 		userVIPInfoMapper.updateByPrimaryKeySelective(info);
+		// 鍙戦�侀偖浠堕�氱煡
+		try {
+			Config config = configService.getConfig(ConfigKeyEnum.extractCodeEmailFrom.getKey());
+			String[] sts = config.getValue().split(",");
+			String account = sts[0];
+			String pwd = sts[1];
+
+			String msg = String.format("鐢ㄦ埛ID:%s 鐢宠瓒呯骇浼氬憳", uid + "");
+			String email = userVipConfigService.getValueByKey("apply_vip_email");
+			String[] emails = email.split(",");
+			for (String e : emails) {
+				MailSenderUtil.sendEmail(e, account, pwd, msg, msg);
+			}
+		} catch (Exception e) {
+			LogHelper.errorDetailInfo(e);
+		}
 	}
 
 	@Transactional(rollbackFor = Exception.class)
@@ -190,7 +215,9 @@
 			throw new UserVIPInfoException(1, "璇ョ敤鎴疯繕涓嶆槸楂樼骇浼氬憳");
 		}
 
-		if (!verifyVip(uid))
+		int verifyVipResult = verifyVip(uid);
+
+		if (verifyVipResult <= 0)
 			throw new UserVIPInfoException(1, "绯荤粺楠岃瘉锛氫笉婊¤冻鍗囩骇鏉′欢");
 
 		Date upgradeTime = new Date();
@@ -205,6 +232,7 @@
 		UserVIPPreInfo preInfo = new UserVIPPreInfo();
 		preInfo.setCreateTime(new Date());
 		preInfo.setProcess(UserLevelEnum.superVIP.getLevel());
+		preInfo.setSourceType(verifyVipResult);
 		preInfo.setUid(uid);
 
 		try {
@@ -238,13 +266,6 @@
 			}
 		} catch (Exception e) {
 			e.printStackTrace();
-		}
-
-		if (!Constant.IS_TEST) {
-			UserLevelChangedMQMsg msg = new UserLevelChangedMQMsg(uid, UserLevelEnum.highVIP, UserLevelEnum.superVIP,
-					new Date());
-			Message message = MQMsgBodyFactory.create(MQTopicName.TOPIC_USER, UserTopicTagEnum.userLevelChanged, msg);
-			producer.send(message);
 		}
 	}
 
@@ -293,11 +314,15 @@
 	}
 
 	/**
-	 * 楠岃瘉鏄惁绗﹀悎VIP
+	 *  楠岃瘉鏄惁绗﹀悎VIP
+	 * @Title: verifyVip
+	 * @Description: 
 	 * @param uid
-	 * @return
+	 * @return 0-涓嶇鍚�  1-璁㈠崟  2-鍥㈤槦
+	 * int 杩斿洖绫诲瀷
+	 * @throws
 	 */
-	private boolean verifyVip(Long uid) {
+	private int verifyVip(Long uid) {
 		// 鑷喘 + 鍒嗕韩璁㈠崟
 		long doneOrder = hongBaoV2CountService.countMyDirectOrderByCashArrival(uid, Constant.VIP_ORDER_PAY);
 		// 鏈夋晥绮変笣
@@ -326,10 +351,14 @@
 			limitSecond = Long.parseLong(second);
 		}
 
-		if (doneOrder >= limitOrder || (doneFirst >= limitFirst && doneSecond >= limitSecond)) {
-			return true;
+		if (doneOrder >= limitOrder) {
+			return UserVIPPreInfo.SOURCE_TYPE_ORDER;
 		}
-		return false;
+
+		if ((doneFirst >= limitFirst && doneSecond >= limitSecond))
+
+			return UserVIPPreInfo.SOURCE_TYPE_TEAM;
+		return 0;
 	}
 
 	@Transactional(rollbackFor = Exception.class)

--
Gitblit v1.8.0