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/order/InviteOrderSubsidyServiceImplV2.java | 124 +++++++++++++++++++++++++++++++++++++++-- 1 files changed, 118 insertions(+), 6 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/order/InviteOrderSubsidyServiceImplV2.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/order/InviteOrderSubsidyServiceImplV2.java index 0343fa6..30be748 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/order/InviteOrderSubsidyServiceImplV2.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/order/InviteOrderSubsidyServiceImplV2.java @@ -2,10 +2,13 @@ import java.math.BigDecimal; import java.util.ArrayList; +import java.util.Calendar; import java.util.Date; +import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Map; +import java.util.Set; import java.util.concurrent.ConcurrentHashMap; import javax.annotation.Resource; @@ -15,21 +18,29 @@ import com.yeshi.fanli.dao.mybatis.order.InviteOrderSubsidyMapper; 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.vip.UserLevelEnum; import com.yeshi.fanli.entity.order.CommonOrder; import com.yeshi.fanli.entity.order.HongBaoOrder; import com.yeshi.fanli.entity.order.InviteOrderSubsidy; +import com.yeshi.fanli.entity.order.OrderTeamReward; +import com.yeshi.fanli.exception.order.CommonOrderException; import com.yeshi.fanli.exception.order.InviteOrderSubsidyException; +import com.yeshi.fanli.exception.order.OrderTeamRewardException; import com.yeshi.fanli.service.inter.order.CommonOrderService; import com.yeshi.fanli.service.inter.order.HongBaoOrderService; import com.yeshi.fanli.service.inter.order.HongBaoV2Service; import com.yeshi.fanli.service.inter.order.InviteOrderSubsidyServiceV2; import com.yeshi.fanli.service.inter.order.OrderHongBaoMapService; import com.yeshi.fanli.service.inter.order.OrderHongBaoMoneyComputeService; +import com.yeshi.fanli.service.inter.order.OrderTeamRewardService; import com.yeshi.fanli.service.inter.order.config.HongBaoManageService; +import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce; import com.yeshi.fanli.service.inter.user.vip.UserVIPInfoService; import com.yeshi.fanli.service.manger.user.UserLevelManager; import com.yeshi.fanli.util.StringUtil; +import com.yeshi.fanli.util.TimeUtil; @Service public class InviteOrderSubsidyServiceImplV2 implements InviteOrderSubsidyServiceV2 { @@ -61,6 +72,12 @@ @Resource private OrderHongBaoMoneyComputeService orderHongBaoMoneyComputeService; + @Resource + private OrderTeamRewardService orderTeamRewardService; + + @Resource + private ThreeSaleSerivce threeSaleSerivce; + @Override public InviteOrderSubsidy getByOrderNoAndType(Long uid, String orderNo, Integer type) { return inviteOrderSubsidyMapper.getByOrderNoAndType(uid, orderNo, type); @@ -72,7 +89,8 @@ } @Transactional(rollbackFor = Exception.class) - private void addOrderSubsidy(InviteOrderSubsidy orderSubsidy) throws InviteOrderSubsidyException { + private void addOrderSubsidy(InviteOrderSubsidy orderSubsidy) + throws InviteOrderSubsidyException, OrderTeamRewardException, CommonOrderException { if (orderSubsidy.getMoney() == null || StringUtil.isNullOrEmpty(orderSubsidy.getOrderNo()) || orderSubsidy.getSourceType() == null || orderSubsidy.getUid() == null) throw new InviteOrderSubsidyException(1, "鏁版嵁涓嶅畬鏁�"); @@ -92,10 +110,77 @@ update.setState(orderSubsidy.getState()); update.setUpdateTime(new Date()); inviteOrderSubsidyMapper.updateByPrimaryKeySelective(update); + // 娣诲姞濂栧姳 + addTeamReward(old.getId()); } else {// 娣诲姞 if (orderSubsidy.getCreateTime() == null) orderSubsidy.setCreateTime(new Date()); inviteOrderSubsidyMapper.insertSelective(orderSubsidy); + // 娣诲姞濂栧姳 + addTeamReward(orderSubsidy.getId()); + } + } + + // 娣诲姞鍥㈤槦濂栧姳 + private void addTeamReward(Long subsidyId) throws OrderTeamRewardException, CommonOrderException { + // 鏌ヨ鍥㈤槦濂栧姳鐨勪汉 + // 璁$畻鐩稿簲鐨勬瘮渚� + InviteOrderSubsidy subsidy = inviteOrderSubsidyMapper.selectByPrimaryKeyForUpdate(subsidyId); + if (subsidy == null) + throw new OrderTeamRewardException(20, "琛ヨ创涓嶅瓨鍦�"); + + // 鑾峰彇涓�4绾х敤鎴� + List<CommonOrder> commonOrderList = commonOrderService.listBySourceTypeAndOrderId(subsidy.getSourceType(), + subsidy.getOrderNo()); + if (commonOrderList == null || commonOrderList.size() == 0) { + throw new CommonOrderException(1, "璁㈠崟涓嶅瓨鍦�"); + } + + Long sourceUid = commonOrderList.get(0).getUserInfo().getId(); + + List<ThreeSale> bossList = threeSaleSerivce.getMyBossDeepList(sourceUid, 4); + // 鏃犻渶瑕佸洟闃熷鍔辩殑涓婄骇 + if (bossList.size() < 3) + return; + + Set<Long> rewardUid = new HashSet<>(); + for (int i = 2; i < bossList.size(); i++) { + rewardUid.add(bossList.get(i).getBoss().getId()); + } + // 鍒犻櫎鏈ˉ璐寸敤鎴风殑涓嬬骇 + for (int i = 0; i < bossList.size(); i++) { + if (bossList.get(i).getBoss().getId().longValue() == subsidy.getUid()) { + break; + } else { + bossList.remove(i); + i--; + } + } + + // 鑾峰彇琛ヨ创鐢ㄦ埛鐨勭洿鎺ヤ笂绾� + if (bossList.size() > 1 && bossList.get(1).getSucceedTime() < subsidy.getCreateTime().getTime()) { + UserInfo boss = bossList.get(1).getBoss(); + UserLevelEnum userLevel = userLevelManager.getUserLevel(boss.getId()); + BigDecimal rewardMoney = orderHongBaoMoneyComputeService.computeFirstTeamReward(subsidy.getMoney(), + subsidy.getCreateTime(), userLevel); + + if (rewardMoney != null) { + // 娣诲姞濂栧姳 + orderTeamRewardService.addOrUpdate(subsidy, rewardMoney, boss.getId(), OrderTeamReward.LEVEL_ONE); + } + + // 鑾峰彇琛ヨ创鐨勯棿鎺ヤ笂绾� + if (bossList.size() > 2 && bossList.get(2).getSucceedTime() < subsidy.getCreateTime().getTime()) { + boss = bossList.get(2).getBoss(); + userLevel = userLevelManager.getUserLevel(boss.getId()); + rewardMoney = orderHongBaoMoneyComputeService.computeSecondTeamReward(subsidy.getMoney(), + subsidy.getCreateTime(), userLevel); + if (rewardMoney != null) { + // 娣诲姞濂栧姳 + orderTeamRewardService.addOrUpdate(subsidy, rewardMoney, boss.getId(), OrderTeamReward.LEVEL_TWO); + } + } + } } @@ -183,9 +268,19 @@ orderSubsidy.setOrderNo(orderId); orderSubsidy.setSourceType(sourceType); orderSubsidy.setState(state); + if (type == HongBaoV2.TYPE_YIJI) + orderSubsidy.setLevel(InviteOrderSubsidy.LEVEL_ONE); + else + orderSubsidy.setLevel(InviteOrderSubsidy.LEVEL_TWO); // 浼氬憳鎵嶈兘琛ヨ创 if (userLevel != UserLevelEnum.daRen) - addOrderSubsidy(orderSubsidy); + try { + addOrderSubsidy(orderSubsidy); + } catch (OrderTeamRewardException e) { + throw new InviteOrderSubsidyException(e.getCode(), e.getMsg()); + } catch (CommonOrderException e) { + throw new InviteOrderSubsidyException(e.getCode(), e.getMsg()); + } } } } @@ -222,7 +317,7 @@ return inviteOrderSubsidyMapper.countByOrderNoAndType(orderId, sourceType); } - @Transactional + @Transactional(rollbackFor = Exception.class) @Override public void invalidByOrderIdAndSourceType(String orderId, int sourceType) { List<InviteOrderSubsidy> list = inviteOrderSubsidyMapper.listByOrderNoAndType(orderId, sourceType); @@ -234,13 +329,29 @@ update.setState(InviteOrderSubsidy.STATE_INVALID); update.setUpdateTime(new Date()); inviteOrderSubsidyMapper.updateByPrimaryKeySelective(update); + orderTeamRewardService.invalidByOrderIdAndSourceType(subsidy.getId()); } } } - @Transactional + @Transactional(rollbackFor = Exception.class) @Override - public void validByOrderIdAndSourceType(String orderId, int sourceType) { + public void validByOrderIdAndSourceType(String orderId, int sourceType) throws InviteOrderSubsidyException { + // 鏌ヨ棰勮鍒拌处鏃堕棿 + List<CommonOrder> orderList = commonOrderService.listBySourceTypeAndOrderId(sourceType, orderId); + if (orderList == null || orderList.size() == 0) + throw new InviteOrderSubsidyException(31, "璁㈠崟涓嶅瓨鍦�"); + + if (orderList.get(0).getSettleTime() == null) + throw new InviteOrderSubsidyException(32, "璁㈠崟灏氭湭纭鏀惰揣"); + + // 纭鏀惰揣鏃堕棿鐨勪笅鏈�25鍙峰埌璐� + Calendar calendar = Calendar.getInstance(); + calendar.setTime(orderList.get(0).getSettleTime()); + calendar.add(Calendar.MONTH, 1); + Date preGetTime = new Date(TimeUtil.convertToTimeTemp( + calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25", "yyyy-M-dd")); + List<InviteOrderSubsidy> list = inviteOrderSubsidyMapper.listByOrderNoAndType(orderId, sourceType); if (list != null && list.size() > 0) for (InviteOrderSubsidy subsidy : list) { @@ -248,10 +359,11 @@ InviteOrderSubsidy update = new InviteOrderSubsidy(subsidy.getId()); update.setState(InviteOrderSubsidy.STATE_VALID); update.setUpdateTime(new Date()); + update.setPreGetTime(preGetTime); inviteOrderSubsidyMapper.updateByPrimaryKeySelective(update); + orderTeamRewardService.validByOrderIdAndSourceType(subsidy.getId(), preGetTime); } } - } @Override -- Gitblit v1.8.0