From 2bd2200f209ddb7bcc59b636d9de6f8b3f762958 Mon Sep 17 00:00:00 2001
From: yujian <yujian@163.com>
Date: 星期四, 23 四月 2020 10:00:26 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/div' into div

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java |  223 +++++++++++++++++++++++++++----------------------------
 1 files changed, 109 insertions(+), 114 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 4423789..3c14853 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
@@ -1,6 +1,5 @@
 package com.yeshi.fanli.service.impl.user.vip;
 
-import java.util.ArrayList;
 import java.util.Date;
 import java.util.HashMap;
 import java.util.List;
@@ -12,42 +11,34 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import com.aliyun.openservices.ons.api.Message;
+import com.aliyun.openservices.ons.api.Producer;
 import com.yeshi.fanli.dao.mybatis.user.vip.UserVIPInfoMapper;
-import com.yeshi.fanli.dto.msg.MsgAccountVipDTO;
-import com.yeshi.fanli.dto.msg.MsgOtherSystemGiveDTO;
-import com.yeshi.fanli.entity.bus.msg.MsgAccountDetail;
-import com.yeshi.fanli.entity.bus.msg.MsgAccountDetail.MsgTypeAccountTypeEnum;
-import com.yeshi.fanli.entity.bus.msg.MsgOtherDetail.MsgTypeOtherTypeEnum;
-import com.yeshi.fanli.entity.bus.user.HongBaoV2;
+import com.yeshi.fanli.dto.mq.user.UserTopicTagEnum;
+import com.yeshi.fanli.dto.mq.user.body.UserLevelChangedMQMsg;
+import com.yeshi.fanli.entity.bus.user.ThreeSale;
 import com.yeshi.fanli.entity.bus.user.UserInfo;
-import com.yeshi.fanli.entity.bus.user.UserInfoExtra;
 import com.yeshi.fanli.entity.bus.user.UserInviteValidNum;
-import com.yeshi.fanli.entity.bus.user.UserSystemCoupon;
+import com.yeshi.fanli.entity.bus.user.vip.UserLevelEnum;
+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.system.SystemCoupon.CouponTypeEnum;
-import com.yeshi.fanli.exception.msg.MsgAccountDetailException;
 import com.yeshi.fanli.exception.user.vip.UserVIPInfoException;
-import com.yeshi.fanli.service.inter.config.ConfigService;
 import com.yeshi.fanli.service.inter.count.HongBaoV2CountService;
-import com.yeshi.fanli.service.inter.msg.UserOtherMsgNotificationService;
-import com.yeshi.fanli.service.inter.shop.BanLiShopOrderService;
-import com.yeshi.fanli.service.inter.user.UserInfoExtraService;
 import com.yeshi.fanli.service.inter.user.UserInfoService;
-import com.yeshi.fanli.service.inter.user.UserInviteSeparateService;
-import com.yeshi.fanli.service.inter.user.UserSystemCouponService;
-import com.yeshi.fanli.service.inter.user.integral.IntegralDetailService;
 import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce;
+import com.yeshi.fanli.service.inter.user.invite.UserInviteMsgNotificationService;
 import com.yeshi.fanli.service.inter.user.invite.UserInviteValidNumService;
-import com.yeshi.fanli.service.inter.user.msg.MsgAccountDetailService;
+import com.yeshi.fanli.service.inter.user.msg.UserAccountMsgNotificationService;
+import com.yeshi.fanli.service.inter.user.vip.UserLevelUpgradedNotifyService;
 import com.yeshi.fanli.service.inter.user.vip.UserVIPInfoService;
 import com.yeshi.fanli.service.inter.user.vip.UserVIPPreInfoService;
 import com.yeshi.fanli.service.inter.user.vip.UserVipConfigService;
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.StringUtil;
-import com.yeshi.fanli.vo.msg.ClientTextStyleVO;
-import com.yeshi.fanli.vo.msg.CommonMsgItemVO;
-import com.yeshi.fanli.vo.msg.CommonMsgItemVOFactory;
+import com.yeshi.fanli.util.TimeUtil;
+import com.yeshi.fanli.util.rocketmq.MQMsgBodyFactory;
+import com.yeshi.fanli.util.rocketmq.MQTopicName;
 
 @Service
 public class UserVIPInfoServiceImpl implements UserVIPInfoService {
@@ -59,45 +50,36 @@
 	private UserInfoService userInfoService;
 
 	@Resource
-	private UserInfoExtraService userInfoExtraService;
-
-	@Resource
 	private UserVipConfigService userVipConfigService;
 
 	@Lazy
 	@Resource
 	private HongBaoV2CountService hongBaoV2CountService;
 
-	@Resource
-	private IntegralDetailService integralDetailService;
-
-	@Resource
-	private BanLiShopOrderService banLiShopOrderService;
-
-	@Resource
-	private UserOtherMsgNotificationService userOtherMsgNotificationService;
 
 	@Resource
 	private ThreeSaleSerivce threeSaleSerivce;
 
-	@Resource
-	private UserInviteSeparateService userInviteSeparateService;
-
-	@Resource
-	private ConfigService configService;
-
-	@Lazy
-	@Resource
-	private UserSystemCouponService userSystemCouponService;
 
 	@Resource
 	private UserVIPPreInfoService userVIPPreInfoService;
 
 	@Resource
-	private MsgAccountDetailService msgAccountDetailService;
+	private UserAccountMsgNotificationService userAccountMsgNotificationService;
 	
 	@Resource
 	private UserInviteValidNumService userInviteValidNumService;
+	
+	@Resource
+	private UserLevelUpgradedNotifyService userLevelUpgradedNotifyService;
+	
+	@Resource
+	private UserInviteMsgNotificationService userInviteMsgNotificationService;
+	
+	@Resource(name = "producer")
+	private Producer producer;
+	
+	
 
 	@Override
 	@Transactional(rollbackFor = Exception.class)
@@ -184,12 +166,11 @@
 		if (userInfo == null) {
 			userInfo = new UserVIPInfo();
 			userInfo.setId(uid);
-			// 娣诲姞璁板綍
 			addUserVIPInfo(userInfo);
 		}
 
 		if (userInfo.getState() != UserVIPInfo.STATE_INVALID)
-			throw new UserVIPInfoException(2, "宸茬粡鐢宠杩�");
+			throw new UserVIPInfoException(2, "绯荤粺宸叉敹鍒颁綘鐨勮秴绾т細鍛樺崌绾х敵璇凤紝灏嗕細灏藉揩瀹屾垚瀹℃牳");
 
 		UserVIPInfo info = new UserVIPInfo();
 		info.setId(userInfo.getId());
@@ -197,20 +178,6 @@
 		info.setState(UserVIPInfo.STATE_VERIFING);
 		info.setUpdateTime(new Date());
 		userVIPInfoMapper.updateByPrimaryKeySelective(info);
-
-		MsgAccountDetail detail = new MsgAccountDetail();
-		detail.setTitle("灏婃暚鐨勯珮绾т細鍛橈紝绯荤粺宸叉敹鍒颁綘鐨勮秴绾т細鍛樺崌绾х敵璇凤紝姝e湪鍙楃悊涓�");
-		detail.setBeiZhu("濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇");
-		detail.setRead(false);
-		detail.setCreateTime(new Date());
-		detail.setUser(new UserInfo(uid));
-		detail.setContent("鎴戜滑灏嗕細鍦�48灏忔椂鍐呭畬鎴愬鏍�");
-		detail.setType(MsgTypeAccountTypeEnum.vipApply);
-		try {
-			msgAccountDetailService.addMsgAccountDetail(detail);
-		} catch (MsgAccountDetailException e) {
-			e.printStackTrace();
-		}
 	}
 
 	@Transactional(rollbackFor = Exception.class)
@@ -231,64 +198,58 @@
 
 		if (!verifyVip(uid))
 			throw new UserVIPInfoException(1, "绯荤粺楠岃瘉锛氫笉婊¤冻鍗囩骇鏉′欢");
-
-		// 棰濆淇℃伅
-		UserInfoExtra userInfoExtra = userInfoExtraService.getByUidForUpdate(uid);
-		if (userInfoExtra == null)
-			throw new UserVIPInfoException(1, "鐢ㄦ埛淇℃伅涓嶅瓨鍦�");
-
+	
+		Date upgradeTime = new Date();
 		// 閫氳繃瓒呯骇浼氬憳
 		UserVIPInfo info = new UserVIPInfo();
 		info.setId(userVIPInfo.getId());
-		info.setSuccessTime(new Date());
+		info.setSuccessTime(upgradeTime);
 		info.setState(UserVIPInfo.STATE_SUCCESS);
-		info.setUpdateTime(new Date());
+		info.setUpdateTime(upgradeTime);
 		userVIPInfoMapper.updateByPrimaryKeySelective(info);
 
+		// 鍗囩骇寮规鎻愮ず
+		UserLevelUpgradedNotify notify = new UserLevelUpgradedNotify();
+		notify.setUid(uid);
+		notify.setFromLevel(UserLevelEnum.highVIP);
+		notify.setToLevel(UserLevelEnum.superVIP);
+		notify.setValid(true);
+		notify.setCreateTime(new Date());
+		userLevelUpgradedNotifyService.addUserLevelUpgradedNotify(notify);
+		
 		try {
-			// 璧犻�佸厤鍗曞埜
-			String giveCoupon = userVipConfigService.getValueByKey("vip_pre_10_gift_givefree_coupon");
-			if (!StringUtil.isNullOrEmpty(giveCoupon)) {
-				int num = Integer.parseInt(giveCoupon);
-				for (int i = 0; i < num; i++) {
-					userSystemCouponService.insertUserCoupon(uid, CouponTypeEnum.freeCouponGive.name(),
-							UserSystemCoupon.SOURCE_SYSTEM_PUSH, null, false);
-				}
-				
-				// 娑堟伅
-				List<CommonMsgItemVO> listMsg = new ArrayList<>();
-				listMsg.add(CommonMsgItemVOFactory.createMsgItemVO(new ClientTextStyleVO("鐘�        鎬�", ClientTextStyleVO.COLOR_TITLE),
-						new ClientTextStyleVO("鎭枩浣狅紒鎴愬姛鍗囩骇涓鸿秴绾т細鍛�", ClientTextStyleVO.COLOR_CONTENT)));
-				listMsg.add(CommonMsgItemVOFactory.createMsgItemVO(new ClientTextStyleVO("濂�        鍔�", ClientTextStyleVO.COLOR_TITLE),
-						new ClientTextStyleVO("鑾峰緱璧犻�佸厤鍗曞埜" + num +"寮�", ClientTextStyleVO.COLOR_CONTENT)));
-				listMsg.add(CommonMsgItemVOFactory.createMsgItemVO(new ClientTextStyleVO("澶�        娉�", ClientTextStyleVO.COLOR_TITLE),
-						new ClientTextStyleVO("璇︽儏鏌ョ湅锛屽搴斾細鍛樻潈鐩�", ClientTextStyleVO.COLOR_CONTENT)));
-				userOtherMsgNotificationService.createMsgOtherDetail(uid, listMsg, MsgTypeOtherTypeEnum.vipUpgradeReward);
+			// 鍗囩骇娑堟伅
+			UserVIPPreInfo pre1 = userVIPPreInfoService.getVipByProcess(uid, UserVIPPreInfo.PROCESS_2);
+			userAccountMsgNotificationService.vipUpgradeSuccess(uid, TimeUtil.getDayDifferenceCount(pre1.getCreateTime(), new Date()));
+			
+			// 鐩存帴绮変笣鍗囩骇鎻愰啋
+			ThreeSale threeSale = threeSaleSerivce.getMyBoss(uid);
+			if (threeSale != null) {
+				Long bossId = threeSale.getBoss().getId();
+				UserInfo userInfo = userInfoService.selectByPKey(uid);
+				userInviteMsgNotificationService.fansUpgrade(bossId,  "瓒呯骇浼氬憳", userInfo.getNickName(), getPassItem(uid), upgradeTime);
 			}
 		} catch (Exception e) {
-			throw new UserVIPInfoException(1, "鍒歌禒閫佸け璐�");
+			e.printStackTrace();
 		}
 		
-		// 娑堟伅
-		MsgAccountVipDTO msgDto = new MsgAccountVipDTO();
-		msgDto.setStatus("宸插皢浣犵殑璐︽埛鐢遍珮绾т細鍛樺崌绾т负瓒呯骇浼氬憳");
-		msgDto.setEquity("浠庢敹鍒版湰娑堟伅璧凤紝浣犲皢鑾峰緱鍏ㄩ儴瓒呯骇浼氬憳鏉冪泭");
-		msgAccountDetailService.addMsgVIP(uid, "鎭枩浣狅紒缁忎汉宸ュ鏍镐綘婊¤冻鍗囩骇瓒呯骇浼氬憳鏉′欢", "濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇", msgDto);
+
+		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);
+		}
 	}
+
 
 	/**
 	 * 楠岃瘉鏄惁绗﹀悎VIP
 	 * @param uid
 	 * @return
 	 */
-	private boolean verifyVip(Long uid) {
-		// 鑷喘璁㈠崟
-		long doneZiGou = hongBaoV2CountService.counOrderByUidAndOrderType(uid, Constant.VIP_ORDER_PAY,
-				HongBaoV2.TYPE_ZIGOU);
-		// 鍒嗕韩璁㈠崟
-		long doneShare = hongBaoV2CountService.counOrderByUidAndOrderType(uid, Constant.VIP_ORDER_PAY,
-				HongBaoV2.TYPE_SHARE_GOODS);
-		
+	private String getPassItem(Long uid) {
+		// 鑷喘 + 鍒嗕韩璁㈠崟
+		long doneOrder = hongBaoV2CountService.countMyDirectOrderByCashArrival(uid, Constant.VIP_ORDER_PAY);
 		// 鏈夋晥绮変笣
 		int doneFirst = 0;
 		int doneSecond = 0;
@@ -298,16 +259,10 @@
 			doneSecond = userInviteValidNum.getNumSecond() == null ? 0 : userInviteValidNum.getNumSecond();
 		}
 
-		long limitZiGou = 0;
-		String zigou = userVipConfigService.getValueByKey("vip_pre_10_zigou_order_count");
+		long limitOrder = 0;
+		String zigou = userVipConfigService.getValueByKey("vip_pre_10_order_count");
 		if (!StringUtil.isNullOrEmpty(zigou)) {
-			limitZiGou = Long.parseLong(zigou);
-		}
-		
-		long limitShare = 0;
-		String share = userVipConfigService.getValueByKey("vip_pre_10_share_order_count");
-		if (!StringUtil.isNullOrEmpty(share)) {
-			limitShare = Long.parseLong(share);
+			limitOrder = Long.parseLong(zigou);
 		}
 		
 		long limitFirst = 0;
@@ -322,7 +277,51 @@
 			limitSecond = Long.parseLong(second);
 		}
 		
-		if (doneZiGou >= limitZiGou || doneShare >= limitShare || (doneFirst >= limitFirst && doneSecond >= limitSecond)) {
+		String item = "";
+		if (doneOrder >= limitOrder) {
+			item = "杩斿埄+鍒嗕韩璁㈠崟";
+		} else if (doneFirst >= limitFirst && doneSecond >= limitSecond) {
+			item = "鐩存帴+闂存帴绮変笣";
+		}
+		return item;
+	}
+	
+	
+	/**
+	 * 楠岃瘉鏄惁绗﹀悎VIP
+	 * @param uid
+	 * @return
+	 */
+	private boolean verifyVip(Long uid) {
+		// 鑷喘 + 鍒嗕韩璁㈠崟
+		long doneOrder = hongBaoV2CountService.countMyDirectOrderByCashArrival(uid, Constant.VIP_ORDER_PAY);
+		// 鏈夋晥绮変笣
+		int doneFirst = 0;
+		int doneSecond = 0;
+		UserInviteValidNum userInviteValidNum = userInviteValidNumService.selectByPrimaryKey(uid);
+		if (userInviteValidNum != null) {
+			doneFirst = userInviteValidNum.getNumFirst() == null ? 0 : userInviteValidNum.getNumFirst();
+			doneSecond = userInviteValidNum.getNumSecond() == null ? 0 : userInviteValidNum.getNumSecond();
+		}
+		long limitOrder = 0;
+		String zigou = userVipConfigService.getValueByKey("vip_pre_10_order_count");
+		if (!StringUtil.isNullOrEmpty(zigou)) {
+			limitOrder = Long.parseLong(zigou);
+		}
+		
+		long limitFirst = 0;
+		String first = userVipConfigService.getValueByKey("vip_pre_10_first_level_team_count");
+		if (!StringUtil.isNullOrEmpty(first)) {
+			limitFirst = Long.parseLong(first);
+		}
+		
+		long limitSecond = 0;
+		String second = userVipConfigService.getValueByKey("vip_pre_10_second_level_team_count");
+		if (!StringUtil.isNullOrEmpty(second)) {
+			limitSecond = Long.parseLong(second);
+		}
+		
+		if (doneOrder >= limitOrder  || (doneFirst >= limitFirst && doneSecond >= limitSecond)) {
 			return true;
 		}
 		return false;
@@ -344,12 +343,8 @@
 		info.setState(UserVIPInfo.STATE_INVALID);
 		info.setUpdateTime(new Date());
 		userVIPInfoMapper.updateByPrimaryKeySelective(info);
-
 		// 娑堟伅
-		MsgAccountVipDTO msgDto = new MsgAccountVipDTO();
-		msgDto.setStatus("浣犵殑璐﹀彿浠嶆槸楂樼骇浼氬憳");
-		msgDto.setReason(reason);
-		msgAccountDetailService.addMsgVIP(uid, "寰堟姳姝夛紒缁忎汉宸ュ鏍镐綘鏈弧瓒虫垨涓嶇鍚堝崌绾ц秴绾т細鍛樼殑鏉′欢", "濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇", msgDto);
+		userAccountMsgNotificationService.vipUpgradeFail(uid, reason);
 	}
 
 }

--
Gitblit v1.8.0