From d8c1cd58845e75f393664a111a6a30aa2754527e Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 10 Feb 2023 16:37:28 +0800
Subject: [PATCH] 增加了支付之前的验证接口

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java |   77 ++++++++++++++++++++++++++++++++++++--
 1 files changed, 73 insertions(+), 4 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java
index 9bb293c..e57eb82 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java
@@ -16,6 +16,8 @@
 import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.mall.vo.*;
+import cc.mrbird.febs.pay.model.MemberWithdrawalDto;
+import cc.mrbird.febs.pay.service.IXcxPayService;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
@@ -64,11 +66,23 @@
     private final MallShopApplyMapper mallShopApplyMapper;
 
     private final IMallMoneyFlowService mallMoneyFlowService;
+    private final MallTeamLeaderMapper mallTeamLeaderMapper;
+
+    private final MallAgentRecordMapper mallAgentRecordMapper;
 
     @Override
     public IPage<MallMember> getMallMemberList(MallMember mallMember, QueryRequest request) {
         Page<MallMember> page = new Page<>(request.getPageNum(), request.getPageSize());
         IPage<MallMember> mallMembers = this.baseMapper.selectMallMemberListInPage(page, mallMember);
+        if(CollUtil.isNotEmpty(mallMembers.getRecords())){
+            for(MallMember mallMemberTeam : mallMembers.getRecords()){
+                String inviteId = mallMemberTeam.getInviteId();
+                MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCodeAndOrderBycreateTime(inviteId);
+                if(ObjectUtil.isNotEmpty(mallTeamLeader)){
+                    mallMemberTeam.setLeaderState(mallTeamLeader.getState() == null ? 0 : mallTeamLeader.getState());
+                }
+            }
+        }
         return mallMembers;
     }
 
@@ -141,6 +155,8 @@
         return adminMoneyChargeListVos;
     }
 
+    private final IXcxPayService iXcxPayService;
+
     @Override
     @Transactional
     public FebsResponse chargeAgree(Long id) {
@@ -152,16 +168,26 @@
         if(1 != mallMemberWithdraw.getStatus()){
             return new FebsResponse().fail().message("当前状态不是提现中");
         }
-        mallMemberWithdraw.setStatus(2);
-        mallMemberWithdrawMapper.updateById(mallMemberWithdraw);
 
         QueryWrapper<MallMoneyFlow> objectQueryWrapper = new QueryWrapper<>();
         objectQueryWrapper.eq("order_no",mallMemberWithdraw.getWithdrawNo());
         objectQueryWrapper.eq("type",MoneyFlowTypeEnum.WITHDRAWAL.getValue());
         MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOne(objectQueryWrapper);
+        Long memberId = mallMemberWithdraw.getMemberId();
+        MallMember mallMember = mallMemberMapper.selectById(memberId);
+        MemberWithdrawalDto memberWithdrawalDto = new MemberWithdrawalDto();
+        memberWithdrawalDto.setDesc("余额提现");
+        memberWithdrawalDto.setOpenid(mallMember.getOpenId());
+        memberWithdrawalDto.setTotalFee(mallMemberWithdraw.getAmount());
+        memberWithdrawalDto.setOutTradeNo(mallMoneyFlow.getOrderNo());
+        Boolean aBoolean = iXcxPayService.memberWithdrawal(memberWithdrawalDto);
+        if(!aBoolean){
+            return new FebsResponse().fail().message("微信提现失败,请查看微信商户状态");
+        }
+        mallMemberWithdraw.setStatus(2);
+        mallMemberWithdrawMapper.updateById(mallMemberWithdraw);
         mallMoneyFlow.setStatus(2);
         mallMoneyFlowMapper.updateById(mallMoneyFlow);
-
         return new FebsResponse().success();
     }
 
@@ -375,7 +401,11 @@
         }
 
         if (isReduce) {
-            iApiMallMemberWalletService.reduce(mallSystemPayDto.getAddBalance().negate(), mallSystemPayDto.getId(), filedType);
+            int i = iApiMallMemberWalletService.reduce(mallSystemPayDto.getAddBalance().negate(), mallSystemPayDto.getId(), filedType);
+
+            if (i == 2) {
+                throw new FebsException("剩余数量不足");
+            }
         } else {
             iApiMallMemberWalletService.add(mallSystemPayDto.getAddBalance(), mallSystemPayDto.getId(), filedType);
         }
@@ -572,6 +602,45 @@
         }
     }
 
+    @Override
+    public IPage<MallAgentRecord> getAgentApplyList(MallAgentRecord mallAgentRecord, QueryRequest request) {
+        Page<MallAgentRecord> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<MallAgentRecord> mallAgentRecords = mallAgentRecordMapper.selectMallAgentRecordListInPage(page, mallAgentRecord);
+        return mallAgentRecords;
+    }
+
+    @Override
+    @Transactional
+    public FebsResponse agreeAgentApply(Long id) {
+        MallAgentRecord mallAgentRecord = mallAgentRecordMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallAgentRecord)){
+            return new FebsResponse().fail().message("申请记录不存在");
+        }
+        mallAgentRecord.setState(MallAgentRecord.APPLY_AGREE);
+        mallAgentRecordMapper.updateById(mallAgentRecord);
+
+        //更新用户表中的LEVEL
+        MallMember mallMember = this.baseMapper.selectById(mallAgentRecord.getMemberId());
+        if(ObjectUtil.isEmpty(mallMember)){
+            return new FebsResponse().fail().message("用户不存在");
+        }
+        mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name());
+        this.baseMapper.updateById(mallMember);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    @Transactional
+    public FebsResponse disagreeAgentApply(Long id) {
+        MallAgentRecord mallAgentRecord = mallAgentRecordMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallAgentRecord)){
+            return new FebsResponse().fail().message("申请记录不存在");
+        }
+        mallAgentRecord.setState(MallAgentRecord.APPLY_DISAGREE);
+        mallAgentRecordMapper.updateById(mallAgentRecord);
+        return new FebsResponse().success();
+    }
+
     private String refererIds(String parentId) {
         boolean flag = false;
         if (StrUtil.isBlank(parentId)) {

--
Gitblit v1.9.1