From 0d91bad397c1a1b41bc77d9cd9f7555ed78f7f1a Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期四, 19 三月 2020 16:57:48 +0800
Subject: [PATCH] 团队奖励相关机制建立

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java |  179 ++++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 116 insertions(+), 63 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 0a913a1..39ae98a 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
@@ -18,12 +18,14 @@
 
 import com.yeshi.fanli.dao.mybatis.user.vip.UserVIPInfoMapper;
 import com.yeshi.fanli.dto.msg.MsgOtherVIPDTO;
+import com.yeshi.fanli.entity.bus.user.HongBaoV2;
 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.UserInviteSeparate;
 import com.yeshi.fanli.entity.bus.user.UserSystemCoupon;
 import com.yeshi.fanli.entity.bus.user.vip.UserVIPInfo;
+import com.yeshi.fanli.entity.bus.user.vip.UserVIPPreInfo;
 import com.yeshi.fanli.entity.integral.IntegralDetail;
 import com.yeshi.fanli.entity.shop.BanLiShopOrder;
 import com.yeshi.fanli.entity.system.ConfigKeyEnum;
@@ -40,6 +42,7 @@
 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.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.TimeUtil;
@@ -49,42 +52,44 @@
 
 	@Resource
 	private UserVIPInfoMapper userVIPInfoMapper;
-	
+
 	@Resource
 	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;
 
 	@Override
 	@Transactional(rollbackFor = Exception.class)
@@ -112,25 +117,25 @@
 		if (userVIPInfo.getState() != UserVIPInfo.STATE_VERIFING) {
 			throw new UserVIPInfoException(2, "鐢宠鏈浜庡鏍哥姸鎬�");
 		}
-		
+
 		if (!verifyConform(uid))
 			throw new UserVIPInfoException(1, "绯荤粺楠岃瘉锛氫笉婊¤冻鍗囩骇鏉′欢");
-		
+
 		UserVIPInfo info = new UserVIPInfo();
 		info.setId(userVIPInfo.getId());
 		info.setSuccessTime(new Date());
 		info.setState(UserVIPInfo.STATE_SUCCESS);
 		info.setUpdateTime(new Date());
 		userVIPInfoMapper.updateByPrimaryKeySelective(info);
-		
+
 		// 涓嬬骇鐨勮秴绾т細鍛� 涓嶈劚绂�
 		userInviteSeparateService.updateInvalidByBossId(uid);
-		
+
 		// 棰濆淇℃伅
 		UserInfoExtra userInfoExtra = userInfoExtraService.getByUidForUpdate(uid);
 		if (userInfoExtra == null)
 			throw new UserVIPInfoException(1, "鐢ㄦ埛淇℃伅涓嶅瓨鍦�");
-		
+
 		// 娣诲姞閲戝竵
 		IntegralDetail detail = new IntegralDetail();
 		detail.setTitle("鍗囩骇VIP绂忓埄");
@@ -140,54 +145,55 @@
 		detail.setUniqueKey("VIP-" + uid);
 		integralDetailService.insertSelective(detail);
 		userInfoExtraService.addGoldCoinByUid(uid, Constant.VIP_COLDCOIN_NUM);
-		
+
 		try {
 			// 濂栧姳鍒�
 			BigDecimal percent = new BigDecimal(configService.get(ConfigKeyEnum.exchangeRebatePercent.getKey()));
 			for (int i = 0; i < Constant.VIP_COUPON_REWARD_NUM; i++) {
-				userSystemCouponService.insertUserCoupon(uid, CouponTypeEnum.rebatePercentCoupon.name(), 
+				userSystemCouponService.insertUserCoupon(uid, CouponTypeEnum.rebatePercentCoupon.name(),
 						UserSystemCoupon.SOURCE_SYSTEM_PUSH, percent, false);
 			}
-			
+
 			// 璧犻�佸厤鍗曞埜
 			for (int i = 0; i < Constant.VIP_COUPON_GIVEFREE_NUM; i++) {
-				userSystemCouponService.insertUserCoupon(uid, CouponTypeEnum.freeCouponGive.name(), 
+				userSystemCouponService.insertUserCoupon(uid, CouponTypeEnum.freeCouponGive.name(),
 						UserSystemCoupon.SOURCE_SYSTEM_PUSH, null, false);
 			}
 		} catch (Exception e) {
 			throw new UserVIPInfoException(1, "鍒歌禒閫佸け璐�");
 		}
-		
+
 		// 娑堟伅
 		MsgOtherVIPDTO msgOther = new MsgOtherVIPDTO();
 		msgOther.setContent1("鎭枩浣狅紝宸叉垚涓鸿秴绾т細鍛�");
 		msgOther.setContent2("婊¤冻鍗囩骇鏉′欢");
 		msgOther.setContent3(TimeUtil.formatDateDot(new Date()));
 		userOtherMsgNotificationService.passVIPApplyMsg(uid, "杩斿埄濂栧姳鍒稿拰銆佽禒閫佸厤鍗曞埜鍜岄噾甯佽鍒版垜鐨�-绂忓埄涓績涓煡鐪�", msgOther);
-		
+
 		// 閫氱煡涓婄骇
 		callBoss(uid);
 	}
 
 	/**
 	 * 閫氱煡涓婄骇鑴辩鍏崇郴
+	 * 
 	 * @param uid
 	 */
 	@Transactional
 	private void callBoss(Long uid) {
 		// 鏄惁瀛樺湪涓婄骇
 		ThreeSale threeSale = threeSaleSerivce.getMyBoss(uid);
-		if (threeSale == null) 
+		if (threeSale == null)
 			return;
 		// 涓婄骇鏄惁涓轰細鍛�
 		Long bossId = threeSale.getBoss().getId();
 		UserVIPInfo bossVIP = userVIPInfoMapper.selectByPrimaryKeyForUpdate(bossId);
 		if (bossVIP != null && bossVIP.getState() != null && bossVIP.getState() == UserVIPInfo.STATE_SUCCESS)
 			return;
-		
+
 		// 涔嬪墠鎻掑叆璁板綍澶辨晥
 		userInviteSeparateService.updateStateByWorkerIdAndBossId(uid, bossId, UserInviteSeparate.STATE_INVALID);
-		
+
 		// 闄愬埗鏃堕棿
 		int limitDays = Integer.parseInt(configService.get(ConfigKeyEnum.inviteSeparateLimitDays.getKey()));
 		UserInviteSeparate inviteSeparate = new UserInviteSeparate();
@@ -198,16 +204,16 @@
 		inviteSeparate.setCreateTime(new Date());
 		inviteSeparate.setUpdateTime(new Date());
 		userInviteSeparateService.insertSelective(inviteSeparate);
-		
+
 		UserInfo userInfo = userInfoService.selectByPKey(uid);
 		// 娑堟伅
 		MsgOtherVIPDTO msgboss = new MsgOtherVIPDTO();
-		msgboss.setContent1(userInfo.getNickName() +" "+ uid);
+		msgboss.setContent1(userInfo.getNickName() + " " + uid);
 		msgboss.setContent2("浜�" + TimeUtil.formatDateDot(new Date()) + "鎴愬姛鍗囩骇鎴愪负瓒呯骇浼氬憳");
-		msgboss.setContent3("浠婃棩璧�"+limitDays+"澶╁唴锛屼綘鏈兘鎴愪负瓒呯骇浼氬憳灏嗕細涓庡叾鑴辩閭�璇峰叧绯� ");
+		msgboss.setContent3("浠婃棩璧�" + limitDays + "澶╁唴锛屼綘鏈兘鎴愪负瓒呯骇浼氬憳灏嗕細涓庡叾鑴辩閭�璇峰叧绯� ");
 		userOtherMsgNotificationService.teamVIPCallBoss(bossId, "濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇", msgboss);
 	}
-	
+
 	@Transactional(rollbackFor = Exception.class)
 	@Override
 	public void rejectVIPApply(Long uid, String reason) throws UserVIPInfoException {
@@ -224,7 +230,7 @@
 		info.setState(UserVIPInfo.STATE_INVALID);
 		info.setUpdateTime(new Date());
 		userVIPInfoMapper.updateByPrimaryKeySelective(info);
-		
+
 		// 娑堟伅
 		MsgOtherVIPDTO msgOther = new MsgOtherVIPDTO();
 		msgOther.setContent1("寰堟姳姝夛紝鏈�氳繃瓒呯骇浼氬憳鐢宠");
@@ -288,19 +294,39 @@
 		return map;
 	}
 
-	
 	@Override
 	public boolean verifyConform(Long uid) {
 		if (uid == null || uid <= 0)
 			return false;
-		
+
 		UserInfoExtra extra = userInfoExtraService.getUserInfoExtra(uid);
-		if (extra == null) 
+		if (extra == null)
 			return false;
-		
+
 		// 1銆佺洿鎺ョ矇涓濓紙浠� 2020 骞� 1 鏈� 1 鏃ヨ捣鐩存帴绮変笣浜х敓鏈夋晥璁㈠崟锛�
 		BigDecimal payMoney = new BigDecimal(userVipConfigService.getValueByKey("require_order_pay"));
-		long teamNum = hongBaoV2CountService.countValidOrderTeamUserByUid(uid, TimeUtil.convertDateToTemp(Constant.VIP_ONLINE_TIME), payMoney);
+//		long teamNum = hongBaoV2CountService.countValidOrderTeamUserByUid(uid,
+//				TimeUtil.convertDateToTemp(Constant.VIP_ONLINE_TIME), payMoney);
+		long teamNum = 0L;
+		long vipBegin = TimeUtil.convertDateToTemp(Constant.VIP_ONLINE_TIME);
+		List<ThreeSale> listThreeSale = threeSaleSerivce.getValidWorkerIdsByTime(uid, vipBegin);
+		if (listThreeSale != null && listThreeSale.size() > 0) {
+			for (ThreeSale three: listThreeSale) {
+				UserInfo worker = three.getWorker();
+				if (worker == null || worker.getId() == null) {
+					continue;
+				}
+				// 1銆侀個璇峰叧绯绘垚鍔熷悗锛�2銆佸崟锛堝垎浜� + 鑷喘锛夊疄浠樻澶т簬1鍏�
+				long countValid = hongBaoV2CountService.countValidOrderByUidAndTime(worker.getId(), three.getSucceedTime(), payMoney);
+				if (countValid > 0) {
+					teamNum ++;
+				}
+			}
+		}
+		
+		
+		
+		
 		
 
 		// 鍖哄垎鑰佺敤鎴峰拰鏂扮敤鎴�
@@ -314,7 +340,7 @@
 		}
 		if (executeDate == null)
 			return false;
-		
+
 		if (extra.getFirstLoginTime() == null || extra.getFirstLoginTime().getTime() < executeDate.getTime()) {
 			long limitNum = Long.parseLong(userVipConfigService.getValueByKey("require_invite_num_old_user"));
 			if (teamNum < limitNum)
@@ -324,19 +350,19 @@
 			if (teamNum < limitNum)
 				return false;
 		}
-		
+
 		// 2銆佺疮璁¤嚜璐繑鍒┾墺100 鍏冿紙浠庢敞鍐屾澘鏍楀揩鐪佽捣锛夛紱
 		BigDecimal fanMoney = new BigDecimal(userVipConfigService.getValueByKey("require_fan_money"));
 		BigDecimal purchase = hongBaoV2CountService.getRewardMoneyBySelf(uid);
 		if (purchase.compareTo(fanMoney) < 0)
 			return false;
-			
+
 		// 3銆佺疮璁¢噾甯佲墺10000 鏋氾紙浠庢敞鍐屾澘鏍楀揩鐪佽捣锛夛紱
 		BigDecimal goldCoin = integralDetailService.getCumulativeMoney(uid);
 		BigDecimal limitGoldCoin = new BigDecimal(userVipConfigService.getValueByKey("require_gold_coin"));
 		if (goldCoin.compareTo(limitGoldCoin) < 0)
 			return false;
-			
+
 		// 4銆佷娇鐢ㄧ孩鍖呪墺1 娆�
 		List<Integer> list = new ArrayList<Integer>();
 		list.add(BanLiShopOrder.STATE_SUCCESS);
@@ -344,73 +370,100 @@
 		long limitHongBao = Long.parseLong(userVipConfigService.getValueByKey("require_shop_buy"));
 		if (useHongBao < limitHongBao)
 			return false;
-			
+
 		// 绗﹀悎鏉′欢
 		return true;
 	}
-	
-	
+
 	@Override
-	public List<UserVIPInfo> listQuery(int page, int count, String key, Integer state){
-		return userVIPInfoMapper.listQuery((page-1) * count, count, key, state);
+	public List<UserVIPInfo> listQuery(int page, int count, String key, Integer state) {
+		return userVIPInfoMapper.listQuery((page - 1) * count, count, key, state);
 	}
-	
+
 	@Override
-	public long countQuery(String key, Integer state){
+	public long countQuery(String key, Integer state) {
 		return userVIPInfoMapper.countQuery(key, state);
 	}
-	
-	
+
 	@Override
 	@Transactional(rollbackFor = Exception.class)
 	public void inviteSeparate(Long workerId, Long bossId) {
 		if (workerId == null || bossId == null)
 			return;
-		
+
 		// 鏌ヨ璁板綍
 		UserInviteSeparate userInviteSeparate = userInviteSeparateService.selectByWorkerIdAndBossId(workerId, bossId);
 		if (userInviteSeparate == null)
 			return;
-		
+
 		// 鏄惁瀛樺湪閭�璇峰叧绯�
 		ThreeSale threeSale = threeSaleSerivce.getMyBoss(workerId);
-		if (threeSale == null) 
+		if (threeSale == null)
 			return;
 		Long bossIdExist = threeSale.getBoss().getId();
 		if (bossIdExist == null || bossId.longValue() != bossIdExist.longValue())
 			return;
-		
+
 		// 涓婄骇浼氬憳鎯呭喌
 		boolean separate = false;
 		UserVIPInfo userVIPInfo = userVIPInfoMapper.selectByPrimaryKey(bossId);
-		if (userVIPInfo != null && userVIPInfo.getState() != null && userVIPInfo.getState() == UserVIPInfo.STATE_SUCCESS) {
+		if (userVIPInfo != null && userVIPInfo.getState() != null
+				&& userVIPInfo.getState() == UserVIPInfo.STATE_SUCCESS) {
 			if (userInviteSeparate.getEndTime().getTime() < userVIPInfo.getSuccessTime().getTime()) {
 				separate = true; // 缁撴潫鏃堕棿宸茬粡瓒呰繃
 			}
 		} else {
-			separate = true; // 涓婄骇闈炰細鍛� 
+			separate = true; // 涓婄骇闈炰細鍛�
 		}
-		
+
 		if (!separate) {
 			// 鏈劚绂�
-			userInviteSeparateService.updateStateByWorkerIdAndBossId(workerId, bossId, UserInviteSeparate.STATE_INVALID);
+			userInviteSeparateService.updateStateByWorkerIdAndBossId(workerId, bossId,
+					UserInviteSeparate.STATE_INVALID);
 		} else {
 			// 鑴辩鍏崇郴
-			userInviteSeparateService.updateStateByWorkerIdAndBossId(workerId, bossId, UserInviteSeparate.STATE_SUCCESS);
-			
+			userInviteSeparateService.updateStateByWorkerIdAndBossId(workerId, bossId,
+					UserInviteSeparate.STATE_SUCCESS);
+
 			// 鑴辩閭�璇峰叧绯�
 			threeSaleSerivce.inviteSeparate(workerId, bossId);
-			
+
 			int limitDays = Integer.parseInt(configService.get(ConfigKeyEnum.inviteSeparateLimitDays.getKey()));
 			// 娑堟伅
 			UserInfo userInfo = userInfoService.selectByPKey(workerId);
 			MsgOtherVIPDTO msgboss = new MsgOtherVIPDTO();
-			msgboss.setContent1(userInfo.getNickName() + workerId + "浜�" +TimeUtil.formatDateDot(userInviteSeparate.getCreateTime())+"鎴愬姛鍗囩骇鎴愪负瓒呯骇浼氬憳 ");
-			msgboss.setContent2("寰堥仐鎲撅紝浣犳湭鑳藉湪"+limitDays+"澶╁崌绾т负瓒呯骇浼氬憳 ");
+			msgboss.setContent1(userInfo.getNickName() + workerId + "浜�"
+					+ TimeUtil.formatDateDot(userInviteSeparate.getCreateTime()) + "鎴愬姛鍗囩骇鎴愪负瓒呯骇浼氬憳 ");
+			msgboss.setContent2("寰堥仐鎲撅紝浣犳湭鑳藉湪" + limitDays + "澶╁崌绾т负瓒呯骇浼氬憳 ");
 			msgboss.setContent3("宸蹭笌鍏惰劚绂婚個璇峰叧绯�");
 			userOtherMsgNotificationService.teamSplitCallBoss(bossId, "濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇", msgboss);
 		}
 	}
-	
+
+	/**
+	 * 楠岃瘉鏄惁绗﹀悎VIP
+	 * @param uid
+	 * @return
+	 */
+	private boolean verifyVip(Long uid) {
+		// 閭�璇疯鍗�
+		long countZiGou = hongBaoV2CountService.counOrderByUidAndOrderType(uid, Constant.VIP_ORDER_PAY,
+				HongBaoV2.TYPE_ZIGOU);
+		// 閭�璇疯鍗�
+		long countShare = hongBaoV2CountService.counOrderByUidAndOrderType(uid, Constant.VIP_ORDER_PAY,
+				HongBaoV2.TYPE_SHARE_GOODS);
+		// 闃熷憳
+		long firstTeam = threeSaleSerivce.countFirstTeam(uid, 1);
+		long secondTeam = threeSaleSerivce.countSecondTeam(uid, 1);
+		if (countZiGou >= Constant.VIP_PROCESS_3_ZIGOU || countShare >= Constant.VIP_PROCESS_3_SHARE
+				|| (firstTeam >= Constant.VIP_PROCESS_3_TEAM && secondTeam >= Constant.VIP_PROCESS_3_TEAM_SECOND)) {
+			UserVIPPreInfo latestProcess = userVIPPreInfoService.getLatestProcessInfo(uid);
+			if (latestProcess == null || latestProcess.getProcess() != UserVIPPreInfo.PROCESS_2) {
+				userVIPPreInfoService.verifyVipPreInfo(uid, false);
+			} 
+			return true;
+		} 
+		return false;
+	}
 	
 }

--
Gitblit v1.8.0