From 29d9b3490f9deca91801be61aeeed9b8d7e432bb Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Thu, 01 Sep 2022 15:53:07 +0800
Subject: [PATCH] 20220822

---
 src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java           |    2 
 src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java                 |   18 +++++++++
 src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java                    |    7 +++
 src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml                  |    8 ++++
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |    3 +
 src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java            |   47 ++++++++++++++++++-----
 src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java          |    4 ++
 7 files changed, 76 insertions(+), 13 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java
index f412625..3315613 100644
--- a/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java
+++ b/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java
@@ -96,7 +96,7 @@
     RECHARGE(18),
 
     /**
-     * 团长提成
+     * 团长提成(收益)
      */
     LEADERACHIEVE(19);
 
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java
index 32cd998..84b0761 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java
@@ -2,6 +2,10 @@
 
 import cc.mrbird.febs.mall.entity.MallMemberWithdraw;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Param;
 
 public interface MallMemberWithdrawMapper extends BaseMapper<MallMemberWithdraw> {
+
+    MallMemberWithdraw selectByWithDrawNoAndMemberIdAndState(@Param("withdrawNo")String withdrawNo, @Param("memberId")Long id, @Param("status")Integer i);
+
 }
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 ccdde6e..917b67b 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
@@ -295,7 +295,7 @@
                 wxResultStr = JSONUtil.toJsonStr(brandWCPayRequestData);
                 payResultStr = brandWCPayRequestData.getPrepay_id();
                 orderInfo.setPayMethod("微信支付");
-                agentProducer.sendOrderReturn(orderInfo.getId());
+//                agentProducer.sendOrderReturn(orderInfo.getId());
                 break;
             case "2":
                 if (StrUtil.isNotBlank(orderInfo.getPayOrderNo())) {
@@ -316,6 +316,7 @@
                 orderInfo.setStatus(OrderStatusEnum.WAIT_SHIPPING.getValue());
                 orderInfo.setPayTime(new Date());
                 orderInfo.setPayResult("1");
+                orderInfo.setDeliveryState(OrderDeliveryStateEnum.DELIVERY_WAIT.getValue());
 
 //                boolean hasTc = false;
 //                // 静态倍数
diff --git a/src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java b/src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java
new file mode 100644
index 0000000..c3e7fec
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java
@@ -0,0 +1,18 @@
+package cc.mrbird.febs.pay.model;
+
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+@Data
+public class MemberWithdrawalDto {
+    //描述
+    private String desc;
+    //提现申请编号
+    private String outTradeNo;
+    //提现金额(分)
+    private BigDecimal totalFee;
+
+    private String openid;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java b/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java
index f433b50..3c9a015 100644
--- a/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java
+++ b/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java
@@ -5,6 +5,7 @@
 import cc.mrbird.febs.mall.dto.RechargeWalletMessageSendDto;
 import cc.mrbird.febs.mall.entity.MallOrderInfo;
 import cc.mrbird.febs.pay.model.BrandWCPayRequestData;
+import cc.mrbird.febs.pay.model.MemberWithdrawalDto;
 import cc.mrbird.febs.pay.model.OrderStateDto;
 import cc.mrbird.febs.pay.model.WxGenerateQrCodeDto;
 
@@ -44,4 +45,10 @@
      * 充值到账消息
      */
     void rechargeWalletMessageSend(RechargeWalletMessageSendDto info);
+
+
+    /**
+     * 用户提现到零钱
+     */
+    Boolean memberWithdrawal(MemberWithdrawalDto info);
 }
diff --git a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
index 1d6ec95..bed6f12 100644
--- a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
@@ -5,19 +5,11 @@
 import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.properties.XcxProperties;
-import cc.mrbird.febs.common.utils.MallUtils;
-import cc.mrbird.febs.common.utils.OssUtils;
-import cc.mrbird.febs.common.utils.RedisUtils;
-import cc.mrbird.febs.common.utils.SpringContextHolder;
+import cc.mrbird.febs.common.utils.*;
 import cc.mrbird.febs.mall.dto.ApiRechargeWalletDto;
 import cc.mrbird.febs.mall.dto.RechargeWalletMessageSendDto;
-import cc.mrbird.febs.mall.entity.DataDictionaryCustom;
-import cc.mrbird.febs.mall.entity.MallMember;
-import cc.mrbird.febs.mall.entity.MallOrderInfo;
-import cc.mrbird.febs.mall.entity.MallOrderItem;
-import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
-import cc.mrbird.febs.mall.mapper.MallMemberMapper;
-import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
+import cc.mrbird.febs.mall.entity.*;
+import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.mall.vo.RechargeWalletMessageSendVo;
 import cc.mrbird.febs.pay.model.*;
@@ -26,6 +18,7 @@
 import cc.mrbird.febs.pay.util.WeixinServiceUtil;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.IdUtil;
+import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.json.JSONObject;
 import cn.hutool.json.JSONUtil;
@@ -61,6 +54,10 @@
     WeixinServiceUtil weixinServiceUtil;
     @Autowired
     private DataDictionaryCustomMapper dataDictionaryCustomMapper;
+    @Autowired
+    private MallMoneyFlowMapper mallMoneyFlowMapper;
+    @Autowired
+    private MallMemberWithdrawMapper mallMemberWithdrawMapper;
     private final IMallMoneyFlowService mallMoneyFlowService;
     @Autowired
     RedisUtils redisUtils;
@@ -119,6 +116,34 @@
     }
 
     @Override
+    public Boolean memberWithdrawal(MemberWithdrawalDto info) {
+        boolean flag=false;
+        BigDecimal unit = new BigDecimal("100");
+        BigDecimal money = new BigDecimal(info.getTotalFee().toString());
+        String outTradeNo = info.getOutTradeNo();
+        String openid = info.getOpenid();
+        String desc = info.getDesc();
+
+        MallMember mallMember = mallMemberMapper.selectMemberByOpenId(openid);
+        if(ObjectUtil.isEmpty(mallMember)){
+            return flag;
+        }
+        MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectByWithDrawNoAndMemberIdAndState(outTradeNo,mallMember.getId(),1);
+        if(ObjectUtil.isEmpty(mallMemberWithdraw)){
+            return flag;
+        }
+        Boolean debug = xcxProperties.getDebug();
+        if (debug) {
+            flag = weixinServiceUtil.comPay("[测试]" + desc, outTradeNo,
+                    1, openid);
+        } else {
+            flag = weixinServiceUtil.comPay(desc, outTradeNo,
+                    unit.multiply(money).intValue(),openid);
+        }
+        return flag;
+    }
+
+    @Override
     public BrandWCPayRequestData startPayment(MallOrderInfo mallOrderInfo) throws Exception {
         BigDecimal unit = new BigDecimal("100");
         BigDecimal money = new BigDecimal(mallOrderInfo.getAmount().toString());
diff --git a/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml b/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml
index 69b88ee..8905ec8 100644
--- a/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml
+++ b/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml
@@ -2,4 +2,12 @@
 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 <mapper namespace="cc.mrbird.febs.mall.mapper.MallMemberWithdrawMapper">
 
+    <select id="selectByWithDrawNoAndMemberIdAndState" resultType="cc.mrbird.febs.mall.entity.MallMemberWithdraw">
+        select a.*
+        from mall_member_withdraw a
+        where a.withdraw_no = #{withdrawNo}
+          and a.member_id = #{memberId}
+          and a.status = #{status}
+    </select>
+
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.1