From 6fdfbf4708f7f7a71b4d63b9adacc56a25161168 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 29 Aug 2022 17:58:16 +0800
Subject: [PATCH] 20220822

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java |  178 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 164 insertions(+), 14 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 a8d6598..6bd1809 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
@@ -58,6 +58,7 @@
     private final IApiMallMemberWalletService iApiMallMemberWalletService;
 
     private final AppVersionMapper appVersionMapper;
+    private final MallMemberWithdrawMapper mallMemberWithdrawMapper;
 
     private final MallNewsInfoMapper mallNewsInfoMapper;
     private final MallShopApplyMapper mallShopApplyMapper;
@@ -96,6 +97,24 @@
     }
 
     @Override
+    public void changeIdentity(Integer type, Long id, Integer value) {
+        MallMember mallMember = mallMemberMapper.selectById(id);
+        if(mallMember == null) {
+            throw new FebsException("参数错误");
+        }
+
+        if (type == 1) {
+            mallMember.setDirector(value);
+        } else if (type == 2){
+            mallMember.setStoreMaster(value);
+        } else {
+            throw new FebsException("参数错误");
+        }
+
+        this.baseMapper.updateById(mallMember);
+    }
+
+    @Override
     public MallMemberVo getMallMemberInfoById(long id) {
         MallMemberVo mallMemberVo = mallMemberMapper.getMallMemberInfoById(id);
         return mallMemberVo;
@@ -125,28 +144,44 @@
     @Override
     @Transactional
     public FebsResponse chargeAgree(Long id) {
-        MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectById(id);
-        if(ObjectUtil.isEmpty(mallMoneyFlow)){
+
+        MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMemberWithdraw)){
             return new FebsResponse().fail().message("系统繁忙,请刷新后重试");
         }
-        if(1 != mallMoneyFlow.getStatus()){
+        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);
         mallMoneyFlow.setStatus(2);
         mallMoneyFlowMapper.updateById(mallMoneyFlow);
+
         return new FebsResponse().success();
     }
 
     @Override
     @Transactional
     public FebsResponse chargeDisagree(Long id) {
-        MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectById(id);
-        if(ObjectUtil.isEmpty(mallMoneyFlow)){
+        MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMemberWithdraw)){
             return new FebsResponse().fail().message("系统繁忙,请刷新后重试");
         }
-        if(1 != mallMoneyFlow.getStatus()){
+        if(1 != mallMemberWithdraw.getStatus()){
             return new FebsResponse().fail().message("当前状态不是提现中");
         }
+        mallMemberWithdraw.setStatus(3);
+        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);
         mallMoneyFlow.setStatus(3);
         mallMoneyFlowMapper.updateById(mallMoneyFlow);
 
@@ -158,8 +193,8 @@
     @Override
     public AdminMallMemberPaymentVo getMallMemberPaymentInfoByFlowId(long id) {
         AdminMallMemberPaymentVo adminMallMemberPaymentVo = new AdminMallMemberPaymentVo();
-        MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectById(id);
-        AdminMallMemberPaymentVo adminMallMemberPaymentVoa = mallMemberPaymentMapper.getMallMemberPaymentInfoByMemberId(mallMoneyFlow.getMemberId());
+        MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectById(id);
+        AdminMallMemberPaymentVo adminMallMemberPaymentVoa = mallMemberPaymentMapper.getMallMemberPaymentInfoByMemberId(mallMemberWithdraw.getMemberId());
         if(ObjectUtil.isNotEmpty(adminMallMemberPaymentVoa)){
             adminMallMemberPaymentVo = adminMallMemberPaymentVoa;
         }
@@ -322,15 +357,33 @@
         }
 
         BigDecimal bigDecimal = mallSystemPayDto.getAddBalance();
+        boolean isReduce = false;
         if(bigDecimal.compareTo(BigDecimal.ZERO) <= 0){
-            return new FebsResponse().fail().message("拨付数目需要大于0");
+            isReduce = true;
         }
 
-        MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
-        mallMemberWallet.setBalance(mallMemberWallet.getBalance().add(bigDecimal));
-        mallMemberWalletMapper.updateBalanceWithId(mallMemberWallet);
+        Integer type = mallSystemPayDto.getType();
+        String filedType = "";
+        if (type == 1) {
+            filedType = "balance";
+        } else if (type == 2) {
+            filedType = "score";
+        } else if (type == 3) {
+            filedType = "prizeScore";
+        } else {
+            throw new FebsException("参数错误");
+        }
 
-        mallMoneyFlowService.addMoneyFlow(memberId, bigDecimal, MoneyFlowTypeEnum.SYSTEM.getValue(), null, FlowTypeEnum.BALANCE.getValue());
+        if (isReduce) {
+            int i = iApiMallMemberWalletService.reduce(mallSystemPayDto.getAddBalance().negate(), mallSystemPayDto.getId(), filedType);
+
+            if (i == 2) {
+                throw new FebsException("剩余数量不足");
+            }
+        } else {
+            iApiMallMemberWalletService.add(mallSystemPayDto.getAddBalance(), mallSystemPayDto.getId(), filedType);
+        }
+        mallMoneyFlowService.addMoneyFlow(memberId, bigDecimal, MoneyFlowTypeEnum.SYSTEM.getValue(), null, type);
         return new FebsResponse().success();
     }
 
@@ -366,6 +419,32 @@
     }
 
     @Override
+    public void resetPwd(String ids, Integer type) {
+        if (StrUtil.isEmpty(ids)) {
+            throw new FebsException("参数错误");
+        }
+        List<String> idList = StrUtil.split(ids, ',');
+
+        for (String s : idList) {
+            Long id = Long.parseLong(s);
+            MallMember member = new MallMember();
+            member.setId(id);
+            member.setCreatedTime(null);
+
+            // 重置交易密码
+            if (type == 1) {
+                String payPwd = SecureUtil.md5("654321");
+                member.setTradePassword(payPwd);
+                // 重置登录密码
+            } else {
+                String pwd = SecureUtil.md5("a123456");
+                member.setPassword(pwd);
+            }
+            this.baseMapper.updateById(member);
+        }
+    }
+
+    @Override
     public IPage<MallDataVo> getMallDataList(MallMember mallMember, QueryRequest request) {
         Page<MallDataVo> page = new Page<>(request.getPageNum(), request.getPageSize());
         IPage<MallDataVo> mallDataVos = this.baseMapper.getMallDataListInPage(page, mallMember);
@@ -390,6 +469,10 @@
         if (!MallShopApply.APPLY_ING.equals(apply.getStatus())) {
             throw new FebsException("申请已审核, 请勿重复操作");
         }
+
+        MallMember member = mallMemberMapper.selectById(apply.getMemberId());
+        member.setStoreMaster(1);
+        mallMemberMapper.updateById(member);
 
         apply.setStatus(MallShopApply.APPLY_AGREE);
         mallShopApplyMapper.updateById(apply);
@@ -430,7 +513,15 @@
         mallMember.setBindPhone(phone);
         mallMember.setLevel(mallUpdateMemberInfoDto.getLevelCode());
         mallMemberMapper.updateById(mallMember);
-
+        if(mallUpdateMemberInfoDto.getBalance() == null){
+            throw new FebsException("请输入正确的余额");
+        }
+        if(mallUpdateMemberInfoDto.getScore() == null){
+            throw new FebsException("请输入正确的赠送积分");
+        }
+        if(mallUpdateMemberInfoDto.getPrizeScore() == null){
+            throw new FebsException("请输入正确的竞猜积分");
+        }
         BigDecimal balance = mallUpdateMemberInfoDto.getBalance();
         if(BigDecimal.ZERO.compareTo(balance) > 0){
             throw new FebsException("请输入正确的余额");
@@ -450,4 +541,63 @@
         mallMemberWalletMapper.updateById(mallMemberWallet);
         return new FebsResponse().success();
     }
+
+    @Override
+    public MallMember findByInviteId(String inviteId) {
+
+        return this.baseMapper.selectInfoByInviteId(inviteId);
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void modifyReferer(MallMember member) {
+        MallMember referer = this.baseMapper.selectInfoByInviteId(member.getReferrerId());
+        if (referer == null) {
+            throw new FebsException("推荐人不存在");
+        }
+        String refererId = member.getReferrerId();
+
+        member = this.baseMapper.selectById(member.getId());
+
+        String beforeReferer = member.getReferrerId();
+        member.setReferrerId(refererId);
+        String refererIds = refererIds(refererId);
+        member.setReferrerIds(refererIds);
+        this.baseMapper.updateById(member);
+
+        List<MallMember> childs = this.baseMapper.selectByRefererId(member.getInviteId());
+        if (CollUtil.isEmpty(childs)) {
+            return;
+        }
+
+        for (MallMember child : childs) {
+            child.setReferrerIds(member.getInviteId() + "," + refererIds);
+            this.baseMapper.updateById(child);
+        }
+    }
+
+    private String refererIds(String parentId) {
+        boolean flag = false;
+        if (StrUtil.isBlank(parentId)) {
+            flag = true;
+        }
+        String ids = "";
+        while (!flag) {
+            if (StrUtil.isBlank(ids)) {
+                ids += parentId;
+            } else {
+                ids += ("," + parentId);
+            }
+            MallMember parentMember = this.baseMapper.selectInfoByInviteId(parentId);
+            if (parentMember == null) {
+                break;
+            }
+            parentId = parentMember.getReferrerId();
+            if (StrUtil.isBlank(parentMember.getReferrerId())) {
+                flag = true;
+            }
+        }
+
+        return ids;
+    }
 }

--
Gitblit v1.9.1