From e5cad818bcfa817ffe7f2af7885cb3b97dbd0ad7 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Tue, 14 Mar 2023 15:46:59 +0800 Subject: [PATCH] 合伙人升级MQ --- src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java | 4 +- src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java | 30 +++++++++------ src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java | 3 + src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java | 3 + src/main/java/cc/mrbird/febs/common/enumerates/MemberLevelEnum.java | 24 ++++++++++++ 5 files changed, 48 insertions(+), 16 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/MemberLevelEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/MemberLevelEnum.java index 3de7868..b6a3c3b 100644 --- a/src/main/java/cc/mrbird/febs/common/enumerates/MemberLevelEnum.java +++ b/src/main/java/cc/mrbird/febs/common/enumerates/MemberLevelEnum.java @@ -43,6 +43,30 @@ return codeOne; } + public String getNextLevel(String Level){ + String levelNext = Level; + int codeOne = 0; + for (MemberLevelEnum value : MemberLevelEnum.values()) { + if(value.type.equals(Level)){ + codeOne = value.code; + break; + } + } + codeOne = codeOne + 1; + for (MemberLevelEnum value : MemberLevelEnum.values()) { + if(value.code == (codeOne)){ + levelNext = value.type; + break; + } + } + return levelNext; + } + +// public static void main(String[] args) { +// String zero_level = MemberLevelEnum.SECOND_LEVEL.getNextLevel("SIX_LEVEL"); +// System.out.println(zero_level); +// } + /** * 比较两个级别的大小,levelOne大于levelTwo返回1,否则返回0 */ diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java index 9f9d2c8..11214b8 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java @@ -59,18 +59,20 @@ List<String> ids = StrUtil.split(member.getReferrerIds(), ','); List<MallMember> parentMembers = memberMapper.selectByInviteIds(ids); for (MallMember parent : parentMembers) { - // 未激活用户无法升级 + // 没有购买套餐无法升级合伙人等级 if (AgentLevelEnum.ZERO_LEVEL.name().equals(member.getLevel())) { continue; } - - DataDictionaryCustom nextLevel = dataDictionaryCustomMapper.selectNextAgentLevelInfo(parent.getLevel()); - if (nextLevel == null) { + //合伙人的下一个层级 + String parentLevel = parent.getLevel(); + String nextLevel = MemberLevelEnum.SECOND_LEVEL.getNextLevel(parentLevel); + if (parentLevel.equals(nextLevel)) { log.info("当前层级无下一级:{}", parent.getLevel()); continue; } - AgentInfo agentInfo = JSONObject.parseObject(nextLevel.getValue(), AgentInfo.class); + DataDictionaryCustom nextLevelDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode("AGENT_LEVEL_REQUIRE", nextLevel); + AgentInfo agentInfo = JSONObject.parseObject(nextLevelDic.getValue(), AgentInfo.class); if (!directMemberCnt(parent, agentInfo)) { continue; } @@ -83,7 +85,7 @@ continue; } - parent.setLevel(nextLevel.getCode()); + parent.setLevel(nextLevel); memberMapper.updateById(parent); } } @@ -104,7 +106,7 @@ return true; } - log.info("用户:{}直推数量未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), childs.size(), agentInfo.getLastAgentCnt()); + log.info("用户:{}直推数量未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), childs.size(), agentInfo.getDirectCnt()); return false; } @@ -142,20 +144,24 @@ } /** - * 团队业绩是否达标 + * 团队贡献点是否达标 * * @param agentInfo * @return */ private boolean teamIncome(MallMember member, AgentInfo agentInfo) { - BigDecimal totalIncome = memberMapper.selectAchieveByMemberId(member.getInviteId(), 2); - BigDecimal targetIncome = agentInfo.getTeamIncome().multiply(new BigDecimal("10000")); - if (totalIncome.compareTo(targetIncome) >= 0) { + List<MallMember> mallMembers = memberMapper.selectAllChildAgentListByInviteId(member.getInviteId()); + List<Long> ids = mallMembers.stream().map(MallMember::getId).collect(Collectors.toList()); + List<MallMemberWallet> mallMemberWallets = mallMemberWalletMapper.selectMemberWalletsByIds(ids); + + int starSum = mallMemberWallets.stream().mapToInt(MallMemberWallet::getStar).sum(); + BigDecimal teamIncome = agentInfo.getTeamIncome(); + if (teamIncome.compareTo(new BigDecimal(starSum)) <= 0) { return true; } - log.info("用户:{}团队业绩未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), totalIncome, targetIncome); + log.info("用户:{}团队贡献点未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), starSum, teamIncome); return false; } diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java index 7b2941a..8bd18c8 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java @@ -351,7 +351,8 @@ changeWallet(orderInfo.getId()); //发送补贴消息 agentProducer.sendPerkMoneyMsg(orderInfo.getId()); -// agentProducer.sendOrderReturn(orderInfo.getId()); + //发送代理自动升级消息 + agentProducer.sendAutoLevelUpMsg(member.getId()); break; case "4": if (orderInfo.getOrderType() != 2) { diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java index 57f047a..7411b14 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java @@ -148,7 +148,8 @@ @Override public void dynamicProfit(Long orderId) { - dynamicProfit(orderId, 2); + return; +// dynamicProfit(orderId, 2); } /** diff --git a/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java b/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java index 964ac30..2bf1c81 100644 --- a/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java +++ b/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java @@ -45,11 +45,11 @@ @RabbitListener(queues = QueueConstants.AGENT_AUTO_LEVEL_UP) public void agentAutoLevelUp(String id) { - log.info("收到代理自动升级消息:{}", id); + log.info("收到合伙人自动升级消息:{}", id); try { agentService.autoUpAgentLevel(Long.parseLong(id)); } catch (Exception e) { - log.error("代理自动升级异常", e); + log.error("合伙人自动升级异常", e); } } -- Gitblit v1.9.1